ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
1 lines • 77.1 kB
Source Map (JSON)
{"version":3,"file":"ng-zorro-antd-slider.mjs","sources":["../../components/slider/slider.service.ts","../../components/slider/handle.component.ts","../../components/slider/marks.component.ts","../../components/slider/step.component.ts","../../components/slider/track.component.ts","../../components/slider/slider.component.ts","../../components/slider/slider.module.ts","../../components/slider/typings.ts","../../components/slider/public-api.ts","../../components/slider/ng-zorro-antd-slider.ts"],"sourcesContent":["/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { Injectable } from '@angular/core';\n\n@Injectable()\nexport class NzSliderService {\n isDragging = false;\n}\n","/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { Direction } from '@angular/cdk/bidi';\nimport { NgStyle } from '@angular/common';\nimport {\n ChangeDetectionStrategy,\n ChangeDetectorRef,\n Component,\n ElementRef,\n Input,\n OnChanges,\n SimpleChanges,\n TemplateRef,\n ViewChild,\n ViewEncapsulation,\n booleanAttribute\n} from '@angular/core';\n\nimport { NgStyleInterface, NzTSType } from 'ng-zorro-antd/core/types';\nimport { numberAttributeWithZeroFallback } from 'ng-zorro-antd/core/util';\nimport { NzToolTipModule, NzTooltipDirective } from 'ng-zorro-antd/tooltip';\n\nimport { NzSliderService } from './slider.service';\nimport { NzSliderShowTooltip } from './typings';\n\n@Component({\n changeDetection: ChangeDetectionStrategy.OnPush,\n encapsulation: ViewEncapsulation.None,\n selector: 'nz-slider-handle',\n exportAs: 'nzSliderHandle',\n preserveWhitespaces: false,\n template: `\n <div\n #handle\n class=\"ant-slider-handle\"\n tabindex=\"0\"\n nz-tooltip\n [ngStyle]=\"style\"\n [nzTooltipTitle]=\"tooltipFormatter === null || tooltipVisible === 'never' ? null : tooltipTitle\"\n [nzTooltipTitleContext]=\"{ $implicit: value }\"\n [nzTooltipTrigger]=\"null\"\n [nzTooltipPlacement]=\"tooltipPlacement\"\n ></div>\n `,\n host: {\n '(mouseenter)': 'enterHandle()',\n '(mouseleave)': 'leaveHandle()'\n },\n imports: [NzToolTipModule, NgStyle],\n standalone: true\n})\nexport class NzSliderHandleComponent implements OnChanges {\n @ViewChild('handle', { static: false }) handleEl?: ElementRef;\n @ViewChild(NzTooltipDirective, { static: false }) tooltip?: NzTooltipDirective;\n\n @Input({ transform: booleanAttribute }) vertical?: boolean;\n @Input({ transform: booleanAttribute }) reverse?: boolean;\n @Input({ transform: numberAttributeWithZeroFallback }) offset?: number;\n @Input({ transform: numberAttributeWithZeroFallback }) value?: number;\n @Input() tooltipVisible: NzSliderShowTooltip = 'default';\n @Input() tooltipPlacement?: string;\n @Input() tooltipFormatter?: null | ((value: number) => string) | TemplateRef<void>;\n @Input({ transform: booleanAttribute }) active = false;\n @Input() dir: Direction = 'ltr';\n\n tooltipTitle?: NzTSType;\n style: NgStyleInterface = {};\n\n constructor(\n private sliderService: NzSliderService,\n private cdr: ChangeDetectorRef\n ) {}\n\n ngOnChanges(changes: SimpleChanges): void {\n const { offset, value, active, tooltipVisible, reverse, dir } = changes;\n\n if (offset || reverse || dir) {\n this.updateStyle();\n }\n\n if (value) {\n this.updateTooltipTitle();\n this.updateTooltipPosition();\n }\n\n if (active) {\n if (active.currentValue) {\n this.toggleTooltip(true);\n } else {\n this.toggleTooltip(false);\n }\n }\n\n if (tooltipVisible?.currentValue === 'always') {\n Promise.resolve().then(() => this.toggleTooltip(true, true));\n }\n }\n\n enterHandle = (): void => {\n if (!this.sliderService.isDragging) {\n this.toggleTooltip(true);\n this.updateTooltipPosition();\n this.cdr.detectChanges();\n }\n };\n\n leaveHandle = (): void => {\n if (!this.sliderService.isDragging) {\n this.toggleTooltip(false);\n this.cdr.detectChanges();\n }\n };\n\n focus(): void {\n this.handleEl?.nativeElement.focus();\n }\n\n private toggleTooltip(show: boolean, force: boolean = false): void {\n if (!force && (this.tooltipVisible !== 'default' || !this.tooltip)) {\n return;\n }\n\n if (show) {\n this.tooltip?.show();\n } else {\n this.tooltip?.hide();\n }\n }\n\n private updateTooltipTitle(): void {\n if (this.tooltipFormatter) {\n this.tooltipTitle =\n typeof this.tooltipFormatter === 'function' ? this.tooltipFormatter(this.value!) : this.tooltipFormatter;\n } else {\n this.tooltipTitle = `${this.value}`;\n }\n }\n\n private updateTooltipPosition(): void {\n if (this.tooltip) {\n Promise.resolve().then(() => this.tooltip?.updatePosition());\n }\n }\n\n private updateStyle(): void {\n const vertical = this.vertical;\n const reverse = this.reverse;\n const offset = this.offset;\n\n const positionStyle = vertical\n ? {\n [reverse ? 'top' : 'bottom']: `${offset}%`,\n [reverse ? 'bottom' : 'top']: 'auto',\n transform: reverse ? null : `translateY(+50%)`\n }\n : {\n ...this.getHorizontalStylePosition(),\n transform: `translateX(${reverse ? (this.dir === 'rtl' ? '-' : '+') : this.dir === 'rtl' ? '+' : '-'}50%)`\n };\n\n this.style = positionStyle;\n this.cdr.markForCheck();\n }\n\n private getHorizontalStylePosition(): { left: string; right: string } {\n let left = this.reverse ? 'auto' : `${this.offset}%`;\n let right = this.reverse ? `${this.offset}%` : 'auto';\n if (this.dir === 'rtl') {\n const tmp = left;\n left = right;\n right = tmp;\n }\n return { left, right };\n }\n}\n","/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { NgStyle } from '@angular/common';\nimport {\n ChangeDetectionStrategy,\n Component,\n Input,\n OnChanges,\n SimpleChanges,\n ViewEncapsulation,\n booleanAttribute,\n numberAttribute\n} from '@angular/core';\n\nimport { NgStyleInterface } from 'ng-zorro-antd/core/types';\n\nimport { NzDisplayedMark, NzExtendedMark, NzMark, NzMarkObj } from './typings';\n\n@Component({\n changeDetection: ChangeDetectionStrategy.OnPush,\n encapsulation: ViewEncapsulation.None,\n preserveWhitespaces: false,\n selector: 'nz-slider-marks',\n exportAs: 'nzSliderMarks',\n template: `\n @for (attr of marks; track attr.value) {\n <span\n class=\"ant-slider-mark-text\"\n [class.ant-slider-mark-active]=\"attr.active\"\n [ngStyle]=\"attr.style!\"\n [innerHTML]=\"attr.label\"\n ></span>\n }\n `,\n imports: [NgStyle],\n standalone: true,\n host: {\n class: 'ant-slider-mark'\n }\n})\nexport class NzSliderMarksComponent implements OnChanges {\n @Input() lowerBound: number | null = null;\n @Input() upperBound: number | null = null;\n @Input() marksArray: NzExtendedMark[] = [];\n @Input({ transform: numberAttribute }) min!: number;\n @Input({ transform: numberAttribute }) max!: number;\n @Input({ transform: booleanAttribute }) vertical = false;\n @Input({ transform: booleanAttribute }) included = false;\n @Input({ transform: booleanAttribute }) reverse!: boolean;\n\n marks: NzDisplayedMark[] = [];\n\n ngOnChanges(changes: SimpleChanges): void {\n const { marksArray, lowerBound, upperBound, reverse } = changes;\n\n if (marksArray || reverse) {\n this.buildMarks();\n }\n\n if (marksArray || lowerBound || upperBound || reverse) {\n this.togglePointActive();\n }\n }\n\n private buildMarks(): void {\n const range = this.max - this.min;\n\n this.marks = this.marksArray.map(mark => {\n const { value, offset, config } = mark;\n const style = this.getMarkStyles(value, range, config);\n const label = isConfigObject(config) ? config.label : config;\n\n return {\n label,\n offset,\n style,\n value,\n config,\n active: false\n };\n });\n }\n\n private getMarkStyles(value: number, range: number, config: NzMark): NgStyleInterface {\n let style;\n const markValue = this.reverse ? this.max + this.min - value : value;\n\n if (this.vertical) {\n style = {\n marginBottom: '-50%',\n bottom: `${((markValue - this.min) / range) * 100}%`\n };\n } else {\n style = {\n transform: `translate3d(-50%, 0, 0)`,\n left: `${((markValue - this.min) / range) * 100}%`\n };\n }\n\n if (isConfigObject(config) && config.style) {\n style = { ...style, ...config.style };\n }\n\n return style;\n }\n\n private togglePointActive(): void {\n if (this.marks && this.lowerBound !== null && this.upperBound !== null) {\n this.marks.forEach(mark => {\n const value = mark.value;\n const isActive =\n (!this.included && value === this.upperBound) ||\n (this.included && value <= this.upperBound! && value >= this.lowerBound!);\n\n mark.active = isActive;\n });\n }\n }\n}\n\nfunction isConfigObject(config: NzMark): config is NzMarkObj {\n return typeof config !== 'string';\n}\n","/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { NgStyle } from '@angular/common';\nimport {\n ChangeDetectionStrategy,\n Component,\n Input,\n OnChanges,\n SimpleChanges,\n ViewEncapsulation,\n booleanAttribute,\n numberAttribute\n} from '@angular/core';\n\nimport { NzDisplayedStep, NzExtendedMark } from './typings';\n\n@Component({\n changeDetection: ChangeDetectionStrategy.OnPush,\n encapsulation: ViewEncapsulation.None,\n selector: 'nz-slider-step',\n exportAs: 'nzSliderStep',\n preserveWhitespaces: false,\n template: `\n @for (step of steps; track step.value) {\n <span class=\"ant-slider-dot\" [class.ant-slider-dot-active]=\"step.active\" [ngStyle]=\"step.style!\"></span>\n }\n `,\n imports: [NgStyle],\n standalone: true,\n host: {\n class: 'ant-slider-step'\n }\n})\nexport class NzSliderStepComponent implements OnChanges {\n @Input() lowerBound: number | null = null;\n @Input() upperBound: number | null = null;\n @Input() marksArray: NzExtendedMark[] = [];\n @Input({ transform: numberAttribute }) min!: number;\n @Input({ transform: numberAttribute }) max!: number;\n @Input({ transform: booleanAttribute }) vertical = false;\n @Input({ transform: booleanAttribute }) included = false;\n @Input({ transform: booleanAttribute }) reverse!: boolean;\n\n steps: NzDisplayedStep[] = [];\n\n ngOnChanges(changes: SimpleChanges): void {\n const { marksArray, lowerBound, upperBound, reverse } = changes;\n\n if (marksArray || reverse) {\n this.buildSteps();\n }\n if (marksArray || lowerBound || upperBound || reverse) {\n this.togglePointActive();\n }\n }\n\n private buildSteps(): void {\n const orient = this.vertical ? 'bottom' : 'left';\n\n this.steps = this.marksArray.map(mark => {\n const { value, config } = mark;\n let offset = mark.offset;\n const range = this.max - this.min;\n\n if (this.reverse) {\n offset = ((this.max - value) / range) * 100;\n }\n\n return {\n value,\n offset,\n config,\n active: false,\n style: {\n [orient]: `${offset}%`,\n transform: this.vertical ? 'translateY(50%)' : 'translateX(-50%)'\n }\n };\n });\n }\n\n private togglePointActive(): void {\n if (this.steps && this.lowerBound !== null && this.upperBound !== null) {\n this.steps.forEach(step => {\n const value = step.value;\n const isActive =\n (!this.included && value === this.upperBound) ||\n (this.included && value <= this.upperBound! && value >= this.lowerBound!);\n step.active = isActive;\n });\n }\n }\n}\n","/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { Direction } from '@angular/cdk/bidi';\nimport { NgStyle } from '@angular/common';\nimport {\n ChangeDetectionStrategy,\n Component,\n Input,\n OnChanges,\n ViewEncapsulation,\n booleanAttribute,\n numberAttribute\n} from '@angular/core';\n\nexport interface NzSliderTrackStyle {\n bottom?: string | null;\n height?: string | null;\n left?: string | null;\n right?: string | null;\n width?: string | null;\n visibility?: string;\n}\n\n@Component({\n changeDetection: ChangeDetectionStrategy.OnPush,\n encapsulation: ViewEncapsulation.None,\n selector: 'nz-slider-track',\n exportAs: 'nzSliderTrack',\n preserveWhitespaces: false,\n template: ` <div class=\"ant-slider-track\" [ngStyle]=\"style\"></div> `,\n imports: [NgStyle],\n standalone: true\n})\nexport class NzSliderTrackComponent implements OnChanges {\n @Input({ transform: numberAttribute }) offset: number = 0;\n @Input({ transform: booleanAttribute }) reverse: boolean = false;\n @Input() dir: Direction = 'ltr';\n @Input({ transform: numberAttribute }) length: number = 0;\n @Input({ transform: booleanAttribute }) vertical = false;\n @Input({ transform: booleanAttribute }) included = false;\n\n style: NzSliderTrackStyle = {};\n\n ngOnChanges(): void {\n const vertical = this.vertical;\n const reverse = this.reverse;\n const visibility = this.included ? 'visible' : 'hidden';\n const offset = this.offset;\n const length = this.length;\n\n const positonStyle: NzSliderTrackStyle = vertical\n ? {\n [reverse ? 'top' : 'bottom']: `${offset}%`,\n [reverse ? 'bottom' : 'top']: 'auto',\n height: `${length}%`,\n visibility\n }\n : {\n ...this.getHorizontalStylePosition(),\n width: `${length}%`,\n visibility\n };\n\n this.style = positonStyle;\n }\n\n private getHorizontalStylePosition(): { left: string; right: string } {\n let left = this.reverse ? 'auto' : `${this.offset}%`;\n let right = this.reverse ? `${this.offset}%` : 'auto';\n if (this.dir === 'rtl') {\n const tmp = left;\n left = right;\n right = tmp;\n }\n return { left, right };\n }\n}\n","/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { Direction, Directionality } from '@angular/cdk/bidi';\nimport { DOWN_ARROW, LEFT_ARROW, RIGHT_ARROW, UP_ARROW } from '@angular/cdk/keycodes';\nimport { Platform } from '@angular/cdk/platform';\nimport {\n ChangeDetectionStrategy,\n ChangeDetectorRef,\n Component,\n ElementRef,\n EventEmitter,\n Input,\n OnChanges,\n OnDestroy,\n OnInit,\n Output,\n QueryList,\n SimpleChanges,\n TemplateRef,\n ViewChildren,\n ViewEncapsulation,\n booleanAttribute,\n forwardRef,\n numberAttribute\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Observable, Subject, Subscription, fromEvent, merge } from 'rxjs';\nimport { distinctUntilChanged, filter, map, takeUntil, tap } from 'rxjs/operators';\n\nimport { NzSafeAny } from 'ng-zorro-antd/core/types';\nimport {\n MouseTouchObserverConfig,\n arraysEqual,\n ensureNumberInRange,\n getElementOffset,\n getPercent,\n getPrecision,\n isNil,\n numberAttributeWithZeroFallback,\n silentEvent\n} from 'ng-zorro-antd/core/util';\n\nimport { NzSliderHandleComponent } from './handle.component';\nimport { NzSliderMarksComponent } from './marks.component';\nimport { NzSliderService } from './slider.service';\nimport { NzSliderStepComponent } from './step.component';\nimport { NzSliderTrackComponent } from './track.component';\nimport { NzExtendedMark, NzMarks, NzSliderHandler, NzSliderShowTooltip, NzSliderValue } from './typings';\n\n@Component({\n changeDetection: ChangeDetectionStrategy.OnPush,\n encapsulation: ViewEncapsulation.None,\n selector: 'nz-slider',\n exportAs: 'nzSlider',\n preserveWhitespaces: false,\n providers: [\n {\n provide: NG_VALUE_ACCESSOR,\n useExisting: forwardRef(() => NzSliderComponent),\n multi: true\n },\n NzSliderService\n ],\n template: `\n <div class=\"ant-slider-rail\"></div>\n <nz-slider-track\n [vertical]=\"nzVertical\"\n [included]=\"nzIncluded\"\n [offset]=\"track.offset!\"\n [length]=\"track.length!\"\n [reverse]=\"nzReverse\"\n [dir]=\"dir\"\n ></nz-slider-track>\n @if (marksArray) {\n <nz-slider-step\n [vertical]=\"nzVertical\"\n [min]=\"nzMin\"\n [max]=\"nzMax\"\n [lowerBound]=\"$any(bounds.lower)\"\n [upperBound]=\"$any(bounds.upper)\"\n [marksArray]=\"marksArray\"\n [included]=\"nzIncluded\"\n [reverse]=\"nzReverse\"\n ></nz-slider-step>\n }\n @for (handle of handles; track handle.value; let handleIndex = $index) {\n <nz-slider-handle\n [vertical]=\"nzVertical\"\n [reverse]=\"nzReverse\"\n [offset]=\"handle.offset!\"\n [value]=\"handle.value!\"\n [active]=\"handle.active\"\n [tooltipFormatter]=\"nzTipFormatter\"\n [tooltipVisible]=\"nzTooltipVisible\"\n [tooltipPlacement]=\"nzTooltipPlacement\"\n [dir]=\"dir\"\n (focusin)=\"onHandleFocusIn(handleIndex)\"\n ></nz-slider-handle>\n }\n @if (marksArray) {\n <nz-slider-marks\n [vertical]=\"nzVertical\"\n [min]=\"nzMin\"\n [max]=\"nzMax\"\n [lowerBound]=\"$any(bounds.lower)\"\n [upperBound]=\"$any(bounds.upper)\"\n [marksArray]=\"marksArray\"\n [included]=\"nzIncluded\"\n [reverse]=\"nzReverse\"\n ></nz-slider-marks>\n }\n `,\n imports: [NzSliderTrackComponent, NzSliderStepComponent, NzSliderHandleComponent, NzSliderMarksComponent],\n standalone: true,\n host: {\n class: 'ant-slider',\n '[class.ant-slider-rtl]': `dir === 'rtl'`,\n '[class.ant-slider-disabled]': 'nzDisabled',\n '[class.ant-slider-vertical]': 'nzVertical',\n '[class.ant-slider-with-marks]': 'marksArray',\n '(keydown)': 'onKeyDown($event)'\n }\n})\nexport class NzSliderComponent implements ControlValueAccessor, OnInit, OnChanges, OnDestroy {\n @ViewChildren(NzSliderHandleComponent) handlerComponents!: QueryList<NzSliderHandleComponent>;\n\n @Input({ transform: booleanAttribute }) nzDisabled = false;\n @Input({ transform: booleanAttribute }) nzDots: boolean = false;\n @Input({ transform: booleanAttribute }) nzIncluded: boolean = true;\n @Input({ transform: booleanAttribute }) nzRange: boolean = false;\n @Input({ transform: booleanAttribute }) nzVertical: boolean = false;\n @Input({ transform: booleanAttribute }) nzReverse: boolean = false;\n @Input() nzDefaultValue?: NzSliderValue;\n @Input() nzMarks: NzMarks | null = null;\n @Input({ transform: numberAttribute }) nzMax = 100;\n @Input({ transform: numberAttribute }) nzMin = 0;\n @Input({ transform: numberAttributeWithZeroFallback }) nzStep: number = 1;\n @Input() nzTooltipVisible: NzSliderShowTooltip = 'default';\n @Input() nzTooltipPlacement: string = 'top';\n @Input() nzTipFormatter?: null | ((value: number) => string) | TemplateRef<void>;\n\n @Output() readonly nzOnAfterChange = new EventEmitter<NzSliderValue>();\n\n value: NzSliderValue | null = null;\n cacheSliderStart: number | null = null;\n cacheSliderLength: number | null = null;\n activeValueIndex: number | undefined = undefined; // Current activated handle's index ONLY for range=true\n track: { offset: null | number; length: null | number } = { offset: null, length: null }; // Track's offset and length\n handles: NzSliderHandler[] = []; // Handles' offset\n marksArray: NzExtendedMark[] | null = null; // \"steps\" in array type with more data & FILTER out the invalid mark\n bounds: { lower: NzSliderValue | null; upper: NzSliderValue | null } = { lower: null, upper: null }; // now for nz-slider-step\n dir: Direction = 'ltr';\n\n private dragStart$?: Observable<number>;\n private dragMove$?: Observable<number>;\n private dragEnd$?: Observable<Event>;\n private dragStart_?: Subscription | null;\n private dragMove_?: Subscription | null;\n private dragEnd_?: Subscription | null;\n private destroy$ = new Subject<boolean>();\n private isNzDisableFirstChange = true;\n\n constructor(\n public slider: ElementRef<HTMLDivElement>,\n private sliderService: NzSliderService,\n private cdr: ChangeDetectorRef,\n private platform: Platform,\n private directionality: Directionality\n ) {}\n\n ngOnInit(): void {\n this.dir = this.directionality.value;\n this.directionality.change?.pipe(takeUntil(this.destroy$)).subscribe((direction: Direction) => {\n this.dir = direction;\n this.cdr.detectChanges();\n this.updateTrackAndHandles();\n this.onValueChange(this.getValue(true));\n });\n\n this.handles = generateHandlers(this.nzRange ? 2 : 1);\n this.marksArray = this.nzMarks ? this.generateMarkItems(this.nzMarks) : null;\n this.bindDraggingHandlers();\n this.toggleDragDisabled(this.nzDisabled);\n\n if (this.getValue() === null) {\n this.setValue(this.formatValue(null));\n }\n }\n\n ngOnChanges(changes: SimpleChanges): void {\n const { nzDisabled, nzMarks, nzRange } = changes;\n\n if (nzDisabled && !nzDisabled.firstChange) {\n this.toggleDragDisabled(nzDisabled.currentValue);\n } else if (nzMarks && !nzMarks.firstChange) {\n this.marksArray = this.nzMarks ? this.generateMarkItems(this.nzMarks) : null;\n } else if (nzRange && !nzRange.firstChange) {\n this.handles = generateHandlers(nzRange.currentValue ? 2 : 1);\n this.setValue(this.formatValue(null));\n }\n }\n\n ngOnDestroy(): void {\n this.unsubscribeDrag();\n this.destroy$.next(true);\n this.destroy$.complete();\n }\n\n writeValue(val: NzSliderValue | null): void {\n this.setValue(val, true);\n }\n\n onValueChange(_value: NzSliderValue): void {}\n\n onTouched(): void {}\n\n registerOnChange(fn: (value: NzSliderValue) => void): void {\n this.onValueChange = fn;\n }\n\n registerOnTouched(fn: () => void): void {\n this.onTouched = fn;\n }\n\n setDisabledState(isDisabled: boolean): void {\n this.nzDisabled = (this.isNzDisableFirstChange && this.nzDisabled) || isDisabled;\n this.isNzDisableFirstChange = false;\n this.toggleDragDisabled(this.nzDisabled);\n this.cdr.markForCheck();\n }\n\n /**\n * Event handler is only triggered when a slider handler is focused.\n */\n onKeyDown(e: KeyboardEvent): void {\n if (this.nzDisabled) {\n return;\n }\n\n const code = e.keyCode;\n const isIncrease = code === RIGHT_ARROW || code === UP_ARROW;\n const isDecrease = code === LEFT_ARROW || code === DOWN_ARROW;\n\n if (!(isIncrease || isDecrease)) {\n return;\n }\n\n e.preventDefault();\n\n let step = (isDecrease ? -this.nzStep : this.nzStep) * (this.nzReverse ? -1 : 1);\n step = this.dir === 'rtl' ? step * -1 : step;\n const newVal = this.nzRange\n ? (this.value as number[])[this.activeValueIndex!] + step\n : (this.value as number) + step;\n this.setActiveValue(ensureNumberInRange(newVal, this.nzMin, this.nzMax));\n this.nzOnAfterChange.emit(this.getValue(true));\n }\n\n onHandleFocusIn(index: number): void {\n this.activeValueIndex = index;\n }\n\n private setValue(value: NzSliderValue | null, isWriteValue: boolean = false): void {\n if (isWriteValue) {\n this.value = this.formatValue(value);\n this.updateTrackAndHandles();\n } else if (!valuesEqual(this.value!, value!)) {\n this.value = value;\n this.updateTrackAndHandles();\n this.onValueChange(this.getValue(true));\n }\n }\n\n private getValue(cloneAndSort: boolean = false): NzSliderValue {\n if (cloneAndSort && this.value && isValueRange(this.value)) {\n return [...this.value].sort((a, b) => a - b);\n }\n return this.value!;\n }\n\n /**\n * Clone & sort current value and convert them to offsets, then return the new one.\n */\n private getValueToOffset(value?: NzSliderValue): NzSliderValue {\n let normalizedValue = value;\n\n if (typeof normalizedValue === 'undefined') {\n normalizedValue = this.getValue(true);\n }\n\n return isValueRange(normalizedValue)\n ? normalizedValue.map(val => this.valueToOffset(val))\n : this.valueToOffset(normalizedValue);\n }\n\n /**\n * Find the closest value to be activated.\n */\n private setActiveValueIndex(pointerValue: number): void {\n const value = this.getValue();\n if (isValueRange(value)) {\n let minimal: number | null = null;\n let gap: number;\n let activeIndex = -1;\n value.forEach((val, index) => {\n gap = Math.abs(pointerValue - val);\n if (minimal === null || gap < minimal!) {\n minimal = gap;\n activeIndex = index;\n }\n });\n this.activeValueIndex = activeIndex;\n this.handlerComponents.toArray()[activeIndex].focus();\n } else {\n this.handlerComponents.toArray()[0].focus();\n }\n }\n\n private setActiveValue(pointerValue: number): void {\n if (isValueRange(this.value!)) {\n const newValue = [...(this.value as number[])];\n newValue[this.activeValueIndex!] = pointerValue;\n this.setValue(newValue);\n } else {\n this.setValue(pointerValue);\n }\n }\n\n /**\n * Update track and handles' position and length.\n */\n private updateTrackAndHandles(): void {\n const value = this.getValue();\n const offset = this.getValueToOffset(value);\n const valueSorted = this.getValue(true);\n const offsetSorted = this.getValueToOffset(valueSorted);\n const boundParts = isValueRange(valueSorted) ? valueSorted : [0, valueSorted];\n const trackParts = isValueRange(offsetSorted)\n ? [offsetSorted[0], offsetSorted[1] - offsetSorted[0]]\n : [0, offsetSorted];\n\n this.handles.forEach((handle, index) => {\n handle.offset = isValueRange(offset) ? offset[index] : offset;\n handle.value = isValueRange(value) ? value[index] : value || 0;\n });\n\n [this.bounds.lower, this.bounds.upper] = boundParts;\n [this.track.offset, this.track.length] = trackParts;\n\n this.cdr.markForCheck();\n }\n\n private onDragStart(value: number): void {\n this.toggleDragMoving(true);\n this.cacheSliderProperty();\n this.setActiveValueIndex(this.getLogicalValue(value));\n this.setActiveValue(this.getLogicalValue(value));\n this.showHandleTooltip(this.nzRange ? this.activeValueIndex : 0);\n }\n\n private onDragMove(value: number): void {\n this.setActiveValue(this.getLogicalValue(value));\n this.cdr.markForCheck();\n }\n\n private getLogicalValue(value: number): number {\n if (this.nzReverse) {\n if (!this.nzVertical && this.dir === 'rtl') {\n return value;\n }\n return this.nzMax - value + this.nzMin;\n }\n if (!this.nzVertical && this.dir === 'rtl') {\n return this.nzMax - value + this.nzMin;\n }\n\n return value;\n }\n\n private onDragEnd(): void {\n this.nzOnAfterChange.emit(this.getValue(true));\n this.toggleDragMoving(false);\n this.cacheSliderProperty(true);\n this.hideAllHandleTooltip();\n this.cdr.markForCheck();\n }\n\n /**\n * Create user interactions handles.\n */\n private bindDraggingHandlers(): void {\n if (!this.platform.isBrowser) {\n return;\n }\n const pluckFunc: (keys: string[]) => (event: Event) => number = keys => (event: Event) =>\n keys.reduce((acc: NzSafeAny, key: string) => acc[key] || acc, event);\n const sliderDOM = this.slider.nativeElement;\n const orientField = this.nzVertical ? 'pageY' : 'pageX';\n const mouse: MouseTouchObserverConfig = {\n start: 'mousedown',\n move: 'mousemove',\n end: 'mouseup',\n pluckKey: [orientField]\n };\n const touch: MouseTouchObserverConfig = {\n start: 'touchstart',\n move: 'touchmove',\n end: 'touchend',\n pluckKey: ['touches', '0', orientField],\n filter: (e: MouseEvent | TouchEvent) => e instanceof TouchEvent\n };\n\n [mouse, touch].forEach(source => {\n const { start, move, end, pluckKey, filter: filterFunc = () => true } = source;\n\n source.startPlucked$ = fromEvent(sliderDOM, start).pipe(\n filter(filterFunc),\n tap(silentEvent),\n map(pluckFunc(pluckKey)),\n map((position: number) => this.findClosestValue(position))\n );\n source.end$ = fromEvent(document, end);\n source.moveResolved$ = fromEvent(document, move).pipe(\n filter(filterFunc),\n tap(silentEvent),\n map(pluckFunc(pluckKey)),\n distinctUntilChanged(),\n map((position: number) => this.findClosestValue(position)),\n distinctUntilChanged(),\n takeUntil(source.end$)\n );\n });\n\n this.dragStart$ = merge(mouse.startPlucked$!, touch.startPlucked$!);\n this.dragMove$ = merge(mouse.moveResolved$!, touch.moveResolved$!);\n this.dragEnd$ = merge(mouse.end$!, touch.end$!);\n }\n\n private subscribeDrag(periods: string[] = ['start', 'move', 'end']): void {\n if (periods.indexOf('start') !== -1 && this.dragStart$ && !this.dragStart_) {\n this.dragStart_ = this.dragStart$.subscribe(this.onDragStart.bind(this));\n }\n\n if (periods.indexOf('move') !== -1 && this.dragMove$ && !this.dragMove_) {\n this.dragMove_ = this.dragMove$.subscribe(this.onDragMove.bind(this));\n }\n\n if (periods.indexOf('end') !== -1 && this.dragEnd$ && !this.dragEnd_) {\n this.dragEnd_ = this.dragEnd$.subscribe(this.onDragEnd.bind(this));\n }\n }\n\n private unsubscribeDrag(periods: string[] = ['start', 'move', 'end']): void {\n if (periods.indexOf('start') !== -1 && this.dragStart_) {\n this.dragStart_.unsubscribe();\n this.dragStart_ = null;\n }\n\n if (periods.indexOf('move') !== -1 && this.dragMove_) {\n this.dragMove_.unsubscribe();\n this.dragMove_ = null;\n }\n\n if (periods.indexOf('end') !== -1 && this.dragEnd_) {\n this.dragEnd_.unsubscribe();\n this.dragEnd_ = null;\n }\n }\n\n private toggleDragMoving(movable: boolean): void {\n const periods = ['move', 'end'];\n if (movable) {\n this.sliderService.isDragging = true;\n this.subscribeDrag(periods);\n } else {\n this.sliderService.isDragging = false;\n this.unsubscribeDrag(periods);\n }\n }\n\n private toggleDragDisabled(disabled: boolean): void {\n if (disabled) {\n this.unsubscribeDrag();\n } else {\n this.subscribeDrag(['start']);\n }\n }\n\n private findClosestValue(position: number): number {\n const sliderStart = this.getSliderStartPosition();\n const sliderLength = this.getSliderLength();\n const ratio = ensureNumberInRange((position - sliderStart) / sliderLength, 0, 1);\n const val = (this.nzMax - this.nzMin) * (this.nzVertical ? 1 - ratio : ratio) + this.nzMin;\n const points =\n this.nzMarks === null\n ? []\n : Object.keys(this.nzMarks)\n .map(parseFloat)\n .sort((a, b) => a - b);\n\n if (this.nzStep !== 0 && !this.nzDots) {\n const closestOne = Math.round(val / this.nzStep) * this.nzStep;\n points.push(closestOne);\n }\n\n const gaps = points.map(point => Math.abs(val - point));\n const closest = points[gaps.indexOf(Math.min(...gaps))];\n\n // return parseFloat(closest.toFixed(getPrecision(this.nzStep)));\n return this.nzStep === 0 ? closest : parseFloat(closest.toFixed(getPrecision(this.nzStep)));\n }\n\n private valueToOffset(value: number): number {\n return getPercent(this.nzMin, this.nzMax, value);\n }\n\n private getSliderStartPosition(): number {\n if (this.cacheSliderStart !== null) {\n return this.cacheSliderStart;\n }\n const offset = getElementOffset(this.slider.nativeElement);\n return this.nzVertical ? offset.top : offset.left;\n }\n\n private getSliderLength(): number {\n if (this.cacheSliderLength !== null) {\n return this.cacheSliderLength;\n }\n const sliderDOM = this.slider.nativeElement;\n return this.nzVertical ? sliderDOM.clientHeight : sliderDOM.clientWidth;\n }\n\n /**\n * Cache DOM layout/reflow operations for performance (may not necessary?)\n */\n private cacheSliderProperty(remove: boolean = false): void {\n this.cacheSliderStart = remove ? null : this.getSliderStartPosition();\n this.cacheSliderLength = remove ? null : this.getSliderLength();\n }\n\n private formatValue(value: NzSliderValue | null): NzSliderValue {\n if (isNil(value)) {\n return this.nzRange ? [this.nzMin, this.nzMax] : this.nzMin;\n } else if (assertValueValid(value, this.nzRange)) {\n return isValueRange(value)\n ? value.map(val => ensureNumberInRange(val, this.nzMin, this.nzMax))\n : ensureNumberInRange(value, this.nzMin, this.nzMax);\n } else {\n return this.nzDefaultValue ? this.nzDefaultValue : this.nzRange ? [this.nzMin, this.nzMax] : this.nzMin;\n }\n }\n\n /**\n * Show one handle's tooltip and hide others'.\n */\n private showHandleTooltip(handleIndex: number = 0): void {\n this.handles.forEach((handle, index) => {\n handle.active = index === handleIndex;\n });\n }\n\n private hideAllHandleTooltip(): void {\n this.handles.forEach(handle => (handle.active = false));\n }\n\n private generateMarkItems(marks: NzMarks): NzExtendedMark[] | null {\n const marksArray: NzExtendedMark[] = [];\n for (const key in marks) {\n if (marks.hasOwnProperty(key)) {\n const mark = marks[key];\n const val = typeof key === 'number' ? key : parseFloat(key);\n if (val >= this.nzMin && val <= this.nzMax) {\n marksArray.push({ value: val, offset: this.valueToOffset(val), config: mark });\n }\n }\n }\n return marksArray.length ? marksArray : null;\n }\n}\n\nfunction getValueTypeNotMatchError(): Error {\n return new Error(\n `The \"nzRange\" can't match the \"ngModel\"'s type, please check these properties: \"nzRange\", \"ngModel\", \"nzDefaultValue\".`\n );\n}\n\nfunction isValueRange(value: NzSliderValue): value is number[] {\n if (value instanceof Array) {\n return value.length === 2;\n } else {\n return false;\n }\n}\n\nfunction generateHandlers(amount: number): NzSliderHandler[] {\n return Array(amount)\n .fill(0)\n .map(() => ({ offset: null, value: null, active: false }));\n}\n\n/**\n * Check if value is valid and throw error if value-type/range not match.\n */\nfunction assertValueValid(value: NzSliderValue, isRange?: boolean): boolean {\n if ((!isValueRange(value) && isNaN(value)) || (isValueRange(value) && value.some(v => isNaN(v)))) {\n return false;\n }\n return assertValueTypeMatch(value, isRange);\n}\n\n/**\n * Assert that if `this.nzRange` is `true`, value is also a range, vice versa.\n */\nfunction assertValueTypeMatch(value: NzSliderValue, isRange: boolean = false): boolean {\n if (isValueRange(value) !== isRange) {\n throw getValueTypeNotMatchError();\n }\n return true;\n}\n\nfunction valuesEqual(valA: NzSliderValue, valB: NzSliderValue): boolean {\n if (typeof valA !== typeof valB) {\n return false;\n }\n return isValueRange(valA) && isValueRange(valB) ? arraysEqual<number>(valA, valB) : valA === valB;\n}\n","/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { NgModule } from '@angular/core';\n\nimport { NzSliderHandleComponent } from './handle.component';\nimport { NzSliderMarksComponent } from './marks.component';\nimport { NzSliderComponent } from './slider.component';\nimport { NzSliderStepComponent } from './step.component';\nimport { NzSliderTrackComponent } from './track.component';\n\n@NgModule({\n imports: [\n NzSliderComponent,\n NzSliderTrackComponent,\n NzSliderHandleComponent,\n NzSliderStepComponent,\n NzSliderMarksComponent\n ],\n exports: [\n NzSliderComponent,\n NzSliderTrackComponent,\n NzSliderHandleComponent,\n NzSliderStepComponent,\n NzSliderMarksComponent\n ]\n})\nexport class NzSliderModule {}\n","/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nexport type NzMark = string | NzMarkObj;\n\nexport interface NzMarkObj {\n style?: object;\n label: string;\n}\n\nexport class NzMarks {\n [key: string]: NzMark;\n}\n\n/**\n * Processed steps that would be passed to sub components.\n */\nexport interface NzExtendedMark {\n value: number;\n offset: number;\n config: NzMark;\n}\n\n/**\n * Marks that would be rendered.\n */\nexport interface NzDisplayedMark extends NzExtendedMark {\n active: boolean;\n label: string;\n style?: object;\n}\n\n/**\n * Steps that would be rendered.\n */\nexport interface NzDisplayedStep extends NzExtendedMark {\n active: boolean;\n style?: object;\n}\n\nexport type NzSliderShowTooltip = 'always' | 'never' | 'default';\n\nexport type NzSliderValue = number[] | number;\n\nexport interface NzSliderHandler {\n offset: number | null;\n value: number | null;\n active: boolean;\n}\n","/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nexport { NzSliderComponent } from './slider.component';\nexport { NzSliderService as ɵNzSliderService } from './slider.service';\nexport { NzSliderModule } from './slider.module';\nexport { NzSliderHandleComponent as ɵNzSliderHandleComponent } from './handle.component';\nexport { NzSliderMarksComponent as ɵNzSliderMarksComponent } from './marks.component';\nexport { NzSliderStepComponent as ɵNzSliderStepComponent } from './step.component';\nexport { NzSliderTrackComponent as ɵNzSliderTrackComponent, NzSliderTrackStyle } from './track.component';\nexport * from './typings';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["i1.NzSliderService","i2"],"mappings":";;;;;;;;;;;;;AAAA;;;AAGG;MAKU,eAAe,CAAA;AAD5B,IAAA,WAAA,GAAA;QAEE,IAAU,CAAA,UAAA,GAAG,KAAK,CAAC;AACpB,KAAA;8GAFY,eAAe,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,UAAA,EAAA,CAAA,CAAA,EAAA;kHAAf,eAAe,EAAA,CAAA,CAAA,EAAA;;2FAAf,eAAe,EAAA,UAAA,EAAA,CAAA;kBAD3B,UAAU;;;MC+CE,uBAAuB,CAAA;IAiBlC,WACU,CAAA,aAA8B,EAC9B,GAAsB,EAAA;QADtB,IAAa,CAAA,aAAA,GAAb,aAAa,CAAiB;QAC9B,IAAG,CAAA,GAAA,GAAH,GAAG,CAAmB;QAXvB,IAAc,CAAA,cAAA,GAAwB,SAAS,CAAC;QAGjB,IAAM,CAAA,MAAA,GAAG,KAAK,CAAC;QAC9C,IAAG,CAAA,GAAA,GAAc,KAAK,CAAC;QAGhC,IAAK,CAAA,KAAA,GAAqB,EAAE,CAAC;QAgC7B,IAAW,CAAA,WAAA,GAAG,MAAW;AACvB,YAAA,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE;AAClC,gBAAA,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;gBACzB,IAAI,CAAC,qBAAqB,EAAE,CAAC;AAC7B,gBAAA,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;aAC1B;AACH,SAAC,CAAC;QAEF,IAAW,CAAA,WAAA,GAAG,MAAW;AACvB,YAAA,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE;AAClC,gBAAA,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;AAC1B,gBAAA,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;aAC1B;AACH,SAAC,CAAC;KAxCE;AAEJ,IAAA,WAAW,CAAC,OAAsB,EAAA;AAChC,QAAA,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,cAAc,EAAE,OAAO,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC;AAExE,QAAA,IAAI,MAAM,IAAI,OAAO,IAAI,GAAG,EAAE;YAC5B,IAAI,CAAC,WAAW,EAAE,CAAC;SACpB;QAED,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC1B,IAAI,CAAC,qBAAqB,EAAE,CAAC;SAC9B;QAED,IAAI,MAAM,EAAE;AACV,YAAA,IAAI,MAAM,CAAC,YAAY,EAAE;AACvB,gBAAA,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;aAC1B;iBAAM;AACL,gBAAA,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;aAC3B;SACF;AAED,QAAA,IAAI,cAAc,EAAE,YAAY,KAAK,QAAQ,EAAE;AAC7C,YAAA,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;SAC9D;KACF;IAiBD,KAAK,GAAA;AACH,QAAA,IAAI,CAAC,QAAQ,EAAE,aAAa,CAAC,KAAK,EAAE,CAAC;KACtC;AAEO,IAAA,aAAa,CAAC,IAAa,EAAE,KAAA,GAAiB,KAAK,EAAA;AACzD,QAAA,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,cAAc,KAAK,SAAS,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YAClE,OAAO;SACR;QAED,IAAI,IAAI,EAAE;AACR,YAAA,IAAI,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC;SACtB;aAAM;AACL,YAAA,IAAI,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC;SACtB;KACF;IAEO,kBAAkB,GAAA;AACxB,QAAA,IAAI,IAAI,CAAC,gBAAgB,EAAE;AACzB,YAAA,IAAI,CAAC,YAAY;gBACf,OAAO,IAAI,CAAC,gBAAgB,KAAK,UAAU,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAM,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC;SAC5G;aAAM;YACL,IAAI,CAAC,YAAY,GAAG,CAAA,EAAG,IAAI,CAAC,KAAK,EAAE,CAAC;SACrC;KACF;IAEO,qBAAqB,GAAA;AAC3B,QAAA,IAAI,IAAI,CAAC,OAAO,EAAE;AAChB,YAAA,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,OAAO,EAAE,cAAc,EAAE,CAAC,CAAC;SAC9D;KACF;IAEO,WAAW,GAAA;AACjB,QAAA,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;AAC/B,QAAA,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;AAC7B,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAE3B,MAAM,aAAa,GAAG,QAAQ;AAC5B,cAAE;AACE,gBAAA,CAAC,OAAO,GAAG,KAAK,GAAG,QAAQ,GAAG,CAAA,EAAG,MAAM,CAAG,CAAA,CAAA;gBAC1C,CAAC,OAAO,GAAG,QAAQ,GAAG,KAAK,GAAG,MAAM;gBACpC,SAAS,EAAE,OAAO,GAAG,IAAI,GAAG,CAAkB,gBAAA,CAAA;AAC/C,aAAA;AACH,cAAE;gBACE,GAAG,IAAI,CAAC,0BAA0B,EAAE;AACpC,gBAAA,SAAS,EAAE,CAAc,WAAA,EAAA,OAAO,IAAI,IAAI,CAAC,GAAG,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,CAAC,GAAG,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,CAAM,IAAA,CAAA;aAC3G,CAAC;AAEN,QAAA,IAAI,CAAC,KAAK,GAAG,aAAa,CAAC;AAC3B,QAAA,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;KACzB;IAEO,0BAA0B,GAAA;AAChC,QAAA,IAAI,IAAI,GAAG,IAAI,CAAC,OAAO,GAAG,MAAM,GAAG,CAAA,EAAG,IAAI,CAAC,MAAM,GAAG,CAAC;AACrD,QAAA,IAAI,KAAK,GAAG,IAAI,CAAC,OAAO,GAAG,CAAG,EAAA,IAAI,CAAC,MAAM,CAAA,CAAA,CAAG,GAAG,MAAM,CAAC;AACtD,QAAA,IAAI,IAAI,CAAC,GAAG,KAAK,KAAK,EAAE;YACtB,MAAM,GAAG,GAAG,IAAI,CAAC;YACjB,IAAI,GAAG,KAAK,CAAC;YACb,KAAK,GAAG,GAAG,CAAC;SACb;AACD,QAAA,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;KACxB;8GA1HU,uBAAuB,EAAA,IAAA,EAAA,CAAA,EAAA,KAAA,EAAAA,eAAA,EAAA,EAAA,EAAA,KAAA,EAAA,EAAA,CAAA,iBAAA,EAAA,CAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA,EAAA;AAAvB,IAAA,SAAA,IAAA,CAAA,IAAA,GAAA,EAAA,CAAA,oBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,IAAA,EAAA,uBAAuB,EAId,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,kBAAA,EAAA,MAAA,EAAA,EAAA,QAAA,EAAA,CAAA,UAAA,EAAA,UAAA,EAAA,gBAAgB,CAChB,EAAA,OAAA,EAAA,CAAA,SAAA,EAAA,SAAA,EAAA,gBAAgB,CAChB,EAAA,MAAA,EAAA,CAAA,QAAA,EAAA,QAAA,EAAA,+BAA+B,CAC/B,EAAA,KAAA,EAAA,CAAA,OAAA,EAAA,OAAA,EAAA,+BAA+B,CAI/B,EAAA,cAAA,EAAA,gBAAA,EAAA,gBAAA,EAAA,kBAAA,EAAA,gBAAA,EAAA,kBAAA,EAAA,MAAA,EAAA,CAAA,QAAA,EAAA,QAAA,EAAA,gBAAgB,CATzB,EAAA,GAAA,EAAA,KAAA,EAAA,EAAA,IAAA,EAAA,EAAA,SAAA,EAAA,EAAA,YAAA,EAAA,eAAA,EAAA,YAAA,EAAA,eAAA,EAAA,EAAA,EAAA,WAAA,EAAA,CAAA,EAAA,YAAA,EAAA,UAAA,EAAA,KAAA,EAAA,IAAA,EAAA,SAAA,EAAA,CAAA,QAAA,CAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,EAAA,YAAA,EAAA,SAAA,EAAA,KAAA,EAAA,IAAA,EAAA,SAAA,EAAA,kBAAkB,EAtBnB,WAAA,EAAA,IAAA,EAAA,CAAA,EAAA,QAAA,EAAA,CAAA,gBAAA,CAAA,EAAA,aAAA,EAAA,IAAA,EAAA,QAAA,EAAA,EAAA,EAAA,QAAA,EAAA,CAAA;;;;;;;;;;;;GAYT,EAKS,QAAA,EAAA,IAAA,EAAA,YAAA,EAAA,CAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EAAA,eAAe,yfAAE,OAAO,EAAA,QAAA,EAAA,WAAA,EAAA,MAAA,EAAA,CAAA,SAAA,CAAA,EAAA,CAAA,EAAA,eAAA,EAAA,EAAA,CAAA,uBAAA,CAAA,MAAA,EAAA,aAAA,EAAA,EAAA,CAAA,iBAAA,CAAA,IAAA,EAAA,CAAA,CAAA,EAAA;;2FAGvB,uBAAuB,EAAA,UAAA,EAAA,CAAA;kBA1BnC,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;oBACT,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;AACrC,oBAAA,QAAQ,EAAE,kBAAkB;AAC5B,oBAAA,QAAQ,EAAE,gBAAgB;AAC1B,oBAAA,mBAAmB,EAAE,KAAK;AAC1B,oBAAA,QAAQ,EAAE,CAAA;;;;;;;;;;;;AAYT,EAAA,CAAA;AACD,oBAAA,IAAI,EAAE;AACJ,wBAAA,cAAc,EAAE,eAAe;AAC/B,wBAAA,cAAc,EAAE,eAAe;AAChC,qBAAA;AACD,oBAAA,OAAO,EAAE,CAAC,eAAe,EAAE,OAAO,CAAC;AACnC,oBAAA,UAAU,EAAE,IAAI;AACjB,iBAAA,CAAA;iHAEyC,QAAQ,EAAA,CAAA;sBAA/C,SAAS;AAAC,gBAAA,IAAA,EAAA,CAAA,QAAQ,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAA;gBACY,OAAO,EAAA,CAAA;sBAAxD,SAAS;AAAC,gBAAA,IAAA,EAAA,CAAA,kBAAkB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAA;gBAER,QAAQ,EAAA,CAAA;sBAA/C,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAA;gBACE,OAAO,EAAA,CAAA;sBAA9C,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAA;gBACiB,MAAM,EAAA,CAAA;sBAA5D,KAAK;uBAAC,EAAE,SAAS,EAAE,+BAA+B,EAAE,CAAA;gBACE,KAAK,EAAA,CAAA;sBAA3D,KAAK;uBAAC,EAAE,SAAS,EAAE,+BAA+B,EAAE,CAAA;gBAC5C,cAAc,EAAA,CAAA;sBAAtB,KAAK;gBACG,gBAAgB,EAAA,CAAA;sBAAxB,KAAK;gBACG,gBAAgB,EAAA,CAAA;sBAAxB,KAAK;gBACkC,MAAM,EAAA,CAAA;sBAA7C,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAA;gBAC7B,GAAG,EAAA,CAAA;sBAAX,KAAK;;;AClER;;;AAGG;MAwCU,sBAAsB,CAAA;AAtBnC,IAAA,WAAA,GAAA;QAuBW,IAAU,CAAA,UAAA,GAAkB,IAAI,CAAC;QACjC,IAAU,CAAA,UAAA,GAAkB,IAAI,CAAC;QACjC,IAAU,CAAA,UAAA,GAAqB,EAAE,CAAC;QAGH,IAAQ,CAAA,QAAA,GAAG,KAAK,CAAC;QACjB,IAAQ,CAAA,QAAA,GAAG,KAAK,CAAC;QAGzD,IAAK,CAAA,KAAA,GAAsB,EAAE,CAAC;AAoE/B,KAAA;AAlEC,IAAA,WAAW,CAAC,OAAsB,EAAA;QAChC,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,UAAU,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC;AAEhE,QAAA,IAAI,UAAU,IAAI,OAAO,EAAE;YACzB,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;QAED,IAAI,UAAU,IAAI,UAAU,IAAI,UAAU,IAAI,OAAO,EAAE;YACrD,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC1B;KACF;IAEO,UAAU,GAAA;QAChB,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC;QAElC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,IAAG;YACtC,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;AACvC,YAAA,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;AACvD,YAAA,MAAM,KAAK,GAAG,cAAc,CAAC,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,GAAG,MAAM,CAAC;YAE7D,OAAO;gBACL,KAAK;gBACL,MAAM;gBACN,KAAK;gBACL,KAAK;gBACL,MAAM;AACN,gBAAA,MAAM,EAAE,KAAK;aACd,CAAC;AACJ,SAAC,CAAC,CAAC;KACJ;AAEO,IAAA,aAAa,CAAC,KAAa,EAAE,KAAa,EAAE,MAAc,EAAA;AAChE,QAAA,IAAI,KAAK,CAAC;QACV,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,KAAK,GAAG,KAAK,CAAC;AAErE,QAAA,IAAI,IAAI,CAAC,QAAQ,EAAE;AACjB,YAAA,KAAK,GAAG;AACN,gBAAA,YAAY,EAAE,MAAM;AACpB,gBAAA,MAAM,EAAE,CAAA,EAAG,CAAC,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,IAAI,KAAK,IAAI,GAAG,CAAG,CAAA,CAAA;aACrD,CAAC;SACH;aAAM;AACL,YAAA,KAAK,GAAG;AACN,gBAAA,SAAS,EAAE,CAAyB,uBAAA,CAAA;AACpC,gBAAA,IAAI,EAAE,CAAA,EAAG,CAAC,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,IAAI,KAAK,IAAI,GAAG,CAAG,CAAA,CAAA;aACnD,CAAC;SACH;QAED,IAAI,cAAc,CAAC,MAAM,CAAC,IAAI,MAAM,CAAC,KAAK,EAAE;YAC1C,KAAK,GAAG,EAAE,GAAG,KAAK,EAAE,GAAG,MAAM,CAAC,KAAK,EAAE,CAAC;SACvC;AAED,QAAA,OAAO,KAAK,CAAC;KACd;IAEO,iBAAiB,GAAA;AACvB,QAAA,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,UAAU,KAAK,IAAI,IAAI,IAAI,CAAC,UAAU,KAAK,IAAI,EAAE;AACtE,YAAA,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,IAAG;AACxB,gBAAA,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;AACzB,gBAAA,MAAM,QAAQ,GACZ,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,KAAK,KAAK,IAAI,CAAC,UAAU;AAC5C,qBAAC,IAAI,CAAC,QAAQ,IAAI,KAAK,IAAI,IAAI,CAAC,UAAW,IAAI,KAAK,IAAI,IAAI,CAAC,UAAW,CAAC,CAAC;AAE5E,gBAAA,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC;AACzB,aAAC,CAAC,CAAC;SACJ;KACF;8GA7EU,sBAAsB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA,EAAA;kGAAtB,sBAAsB,EAAA,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,iBAAA,EAAA,MAAA,EAAA,EAAA,UAAA,EAAA,YAAA,EAAA,UAAA,EAAA,YAAA,EAAA,UAAA,EAAA,YAAA,EAAA,GAAA,EAAA,CAAA,KAAA,EAAA,KAAA,EAIb,eAAe,CAAA,EAAA,GAAA,EAAA,CAAA,KAAA,EAAA,KAAA,EACf,eAAe,CAAA,EAAA,QAAA,EAAA,CAAA,UAAA,EAAA,UAAA,EACf,gBAAgB,CAChB,EAAA,QAAA,EAAA,CAAA,UAAA,EAAA,UAAA,EAAA,gBAAgB,CAChB,EAAA,OAAA,EAAA,CAAA,SAAA,EAAA,SAAA,EAAA,gBAAgB,CAxB1B,EAAA,EAAA,IAAA,EAAA,EAAA,cAAA,EAAA,iBAAA,EAAA,EAAA,QAAA,EAAA,CAAA,eAAA,CAAA,EAAA,aAAA,EAAA,IAAA,EAAA,QAAA,EAAA,EAAA,EAAA,QAAA,EAAA,CAAA;;;;;;;;;AAST,EAAA,CAAA,EAAA,QAAA,EAAA,IAAA,EAAA,YAAA,EAAA,CAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EACS,OAAO,EAAA,QAAA,EAAA,WAAA,EAAA,MAAA,EAAA,CAAA,SAAA,CAAA,EAAA,CAAA,EAAA,eAAA,EAAA,EAAA,CAAA,uBAAA,CAAA,MAAA,EAAA,aAAA,EAAA,EAAA,CAAA,iBAAA,CAAA,IAAA,EAAA,CAAA,CAAA,EAAA;;2FAMN,sBAAsB,EAAA,UAAA,EAAA,CAAA;kBAtBlC,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;oBACT,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;AACrC,oBAAA,mBAAmB,EAAE,KAAK;AAC1B,oBAAA,QAAQ,EAAE,iBAAiB;AAC3B,oBAAA,QAAQ,EAAE,eAAe;AACzB,oBAAA,QAAQ,EAAE,CAAA;;;;;;;;;AAST,EAAA,CAAA;oBACD,OAAO,EAAE,CAAC,OAAO,CAAC;AAClB,oBAAA,UAAU,EAAE,IAAI;AAChB,oBAAA,IAAI,EAAE;AACJ,wBAAA,KAAK,EAAE,iBAAiB;AACzB,qBAAA;AACF,iBAAA,CAAA;8BAEU,UAAU,EAAA,CAAA;sBAAlB,KAAK;gBACG,UAAU,EAAA,CAAA;sBAAlB,KAAK;gBACG,UAAU,EAAA,CAAA;sBAAlB,KAAK;gBACiC,GAAG,EAAA,CAAA;sBAAzC,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE,CAAA;gBACE,GAAG,EAAA,CAAA;sBAAzC,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE,CAAA;gBACG,QAAQ,EAAA,CAAA;sBAA/C,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAA;gBACE,QAAQ,EAAA,CAAA;sBAA/C,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAA;gBACE,OAAO,EAAA,CAAA;sBAA9C,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAA;;AAwExC,SAAS,cAAc,CAAC,MAAc,EAAA;AACpC,IAAA,OAAO,OAAO,MAAM,KAAK,QAAQ,CAAC;AACpC;;AC7HA;;;AAGG;MAiCU,qBAAqB,CAAA;AAjBlC,IAAA,WAAA,GAAA;QAkBW,IAAU,CAAA,UAAA,GAAkB,IAAI,CAAC;QACjC,IAAU,CAAA,UAAA,GAAkB,IAAI,CAAC;QACjC,IAAU,CAAA,UAAA,GAAqB,EAAE,CAAC;QAGH,IAAQ,CAAA,QAAA,GAAG,KAAK,CAAC;QACjB,IAAQ,CAAA,QAAA,GAAG,KAAK,CAAC;QAGzD,IAAK,CAAA,KAAA,GAAsB,EAAE,CAAC;AAiD/B,KAAA;AA/CC,IAAA,WAAW,CAAC,OAAsB,EAAA;QAChC,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,UAAU,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC;AAEhE,QAAA,IAAI,UAAU,IAAI,OAAO,EAAE;YACzB,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;QACD,IAAI,UAAU,IAAI,UAAU,IAAI,UAAU,IAAI,OAAO,EAAE;YACrD,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC1B;KACF;IAEO,UAAU,GAAA;AAChB,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,GAAG,QAAQ,GAAG,MAAM,CAAC;QAEjD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,IAAG;AACtC,YAAA,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;AAC/B,YAAA,IAAI,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YACzB,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC;AAElC,YAAA,IAAI,IAAI,CAAC,OAAO,EAAE;AAChB,gBAAA,MAAM,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,GAAG