ca-components 1.6.693 → 1.7.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -18,10 +18,12 @@ import * as i2 from "@angular/common";
18
18
  export class CaCustomDatetimePickersComponent {
19
19
  set inputConfig(config) {
20
20
  this._inputConfig = config;
21
- if (this._inputConfig.name === InputConfigNameStringEnum.DATE_PICKER_BANK_CARD)
21
+ if (this._inputConfig.name ===
22
+ InputConfigNameStringEnum.DATE_PICKER_BANK_CARD)
22
23
  this.listPreview = CalendarListPreviewStringEnum.MONTH_LIST;
23
24
  if (this._inputConfig.minutesGapFive)
24
- this.timeMinutes = CustomDatetimePickersConstants.timeMinutesGapFive;
25
+ this.timeMinutes =
26
+ CustomDatetimePickersConstants.timeMinutesGapFive;
25
27
  else
26
28
  this.timeMinutes = CustomDatetimePickersConstants.timeMinutes;
27
29
  }
@@ -50,14 +52,17 @@ export class CaCustomDatetimePickersComponent {
50
52
  set calendarType(calendarType) {
51
53
  this.calendarMainType = calendarType;
52
54
  if (calendarType === CalendarTypeStringEnum.TIME)
53
- this.outputType = CustomDatetimePickersConstants.defaultOutputTypeTime;
55
+ this.outputType =
56
+ CustomDatetimePickersConstants.defaultOutputTypeTime;
54
57
  else
55
- this.outputType = CustomDatetimePickersConstants.defaultOutputTypeDate;
58
+ this.outputType =
59
+ CustomDatetimePickersConstants.defaultOutputTypeDate;
56
60
  }
57
61
  set placeholder(placeholder) {
58
62
  this.selectedDateTime = placeholder;
59
63
  }
60
64
  ngOnInit() {
65
+ console.log(this.dateTime, ' this. dadateTime');
61
66
  this.initDateChangedListener();
62
67
  }
63
68
  ngAfterViewInit() {
@@ -75,7 +80,9 @@ export class CaCustomDatetimePickersComponent {
75
80
  });
76
81
  }
77
82
  setTimeValue() {
78
- const dateInputArray = moment(this.dateTime).format('H/mm/A').split('/');
83
+ const dateInputArray = moment(this.dateTime)
84
+ .format('H/mm/A')
85
+ .split('/');
79
86
  setTimeout(() => {
80
87
  this.scrollTypes.hourScroll = this.hourTimes.indexOf(parseInt(dateInputArray[0]));
81
88
  this.scrollTypes.minutesScroll = this.timeMinutes.indexOf(dateInputArray[1]);
@@ -140,12 +147,12 @@ export class CaCustomDatetimePickersComponent {
140
147
  this.scrollTypes[type] = scrollIndex;
141
148
  }
142
149
  else if (index !== null) {
143
- event.target.parentNode.scrollTop =
144
- scrollIndex * 22;
150
+ (event.target.parentNode).scrollTop = scrollIndex * 22;
145
151
  this.scrollTypes[type] = scrollIndex;
146
152
  }
147
153
  else {
148
- event.target.scrollTop = (scrollIndex + 1) * 22;
154
+ event.target.scrollTop =
155
+ (scrollIndex + 1) * 22;
149
156
  this.scrollTypes[type] = scrollIndex + 1;
150
157
  }
151
158
  this.checkForScrolledType(type);
@@ -219,4 +226,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
219
226
  }], placeholder: [{
220
227
  type: Input
221
228
  }] } });
222
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-custom-datetime-pickers.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-custom-datetime-pickers/ca-custom-datetime-pickers.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-custom-datetime-pickers/ca-custom-datetime-pickers.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  ViewChild,\n  ViewContainerRef,\n  OnDestroy,\n  AfterViewInit,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\n\n// moment\nimport moment from 'moment';\n\n// services\nimport { CalendarDateTimePickerService } from './services/calendar-datetime-picker.service';\n\n// components\nimport { CaCustomDateTimePickersDateCalendarsComponent } from './components/ca-custom-datetime-pickers-date-calendars/ca-custom-datetime-pickers-date-calendars.component';\n\n// constants\nimport { CustomDatetimePickersConstants } from './utils/constants/custom-datetime-pickers.constants';\n\n// models\nimport { ICaInput } from '../ca-input/config/ca-input.config';\nimport { ScrollType } from './models/scroll-type.model';\n\n// enums\nimport { InputConfigNameStringEnum } from '../ca-input/enums/input-config-name-string.enum';\nimport { CalendarTypeStringEnum } from './enums/calendar-type-string.enum';\nimport { CalendarListPreviewStringEnum } from './enums/calendar-list-preview-string.enum';\nimport { CalendarScrollTypeStringEnum } from './enums/calendar-scroll-type-string.enum';\n\n@Component({\n  selector: 'ca-custom-datetime-pickers',\n  templateUrl: './ca-custom-datetime-pickers.component.html',\n  styleUrls: ['./ca-custom-datetime-pickers.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    CaCustomDateTimePickersDateCalendarsComponent,\n  ],\n})\nexport class CaCustomDatetimePickersComponent\n  implements OnInit, OnDestroy, AfterViewInit {\n  @Input() dateTime!: Date;\n  @ViewChild('ref', { read: ViewContainerRef }) ref!: ViewContainerRef;\n  public _inputConfig!: ICaInput;\n  @Input() set inputConfig(config: ICaInput) {\n    this._inputConfig = config;\n    if (\n      this._inputConfig.name === InputConfigNameStringEnum.DATE_PICKER_BANK_CARD\n    )\n      this.listPreview = CalendarListPreviewStringEnum.MONTH_LIST;\n\n    if (this._inputConfig.minutesGapFive)\n      this.timeMinutes = CustomDatetimePickersConstants.timeMinutesGapFive;\n    else this.timeMinutes = CustomDatetimePickersConstants.timeMinutes;\n  }\n\n  @Output() closePopover: EventEmitter<void> = new EventEmitter();\n\n  @ViewChild(CaCustomDateTimePickersDateCalendarsComponent)\n  dateCalendar!: CaCustomDateTimePickersDateCalendarsComponent;\n  @ViewChild('pmAmScroll') pmAmScroll!: ElementRef;\n  @ViewChild('minutesScroll') minutesScroll!: ElementRef;\n  @ViewChild('hourScroll') hourScroll!: ElementRef;\n\n  public selectedDateTime!: string;\n  public calendarMainType!: string;\n  public outputType!: (string | number)[];\n  public currentYear: number = new Date().getFullYear();\n  public currentMonth: number = new Date().getMonth();\n  public currentDay: number = new Date().getDate();\n  public listPreview: string = CalendarListPreviewStringEnum.FULL_LIST;\n  public timeMinutes!: string[];\n  public monthArray: number[] = new Array(12)\n    .fill(0)\n    .map((_, indx) => indx + 1);\n  public monthDayList: number[] = new Array(31)\n    .fill(0)\n    .map((_, indx) => indx + 1);\n  public yearsList: (string | number)[] = new Array(100)\n    .fill(0)\n    .map((_, idx) => (idx < 10 ? '0' + idx : idx));\n  public scrollTimer!: ReturnType<typeof setTimeout> | number;\n  public hoveredItem!: string | null;\n  public isInputFocus!: boolean;\n  public monthNames: string[] = CustomDatetimePickersConstants.monthNames;\n  public hourTimes: number[] = CustomDatetimePickersConstants.hourTimes;\n  public scrollTypes: ScrollType =\n    CustomDatetimePickersConstants.defaultScrollTypes;\n  public selectedTime: string =\n    CustomDatetimePickersConstants.defaultSelectedTime;\n  public timeOfDay: string[] = CustomDatetimePickersConstants.timeOfDay;\n\n  public previousRangeSide!: boolean;\n\n  constructor(private calendarService: CalendarDateTimePickerService) { }\n\n  @Input()\n  set calendarType(calendarType: string) {\n    this.calendarMainType = calendarType;\n    if (calendarType === CalendarTypeStringEnum.TIME)\n      this.outputType = CustomDatetimePickersConstants.defaultOutputTypeTime;\n    else this.outputType = CustomDatetimePickersConstants.defaultOutputTypeDate;\n  }\n\n  @Input()\n  set placeholder(placeholder: string) {\n    this.selectedDateTime = placeholder;\n  }\n\n  ngOnInit(): void {\n    this.initDateChangedListener();\n  }\n\n  ngAfterViewInit(): void {\n    this.setTimeValue();\n    this.changeOpened();\n  }\n\n  public initDateChangedListener(): void {\n    this.calendarService.dateChanged.subscribe((date) => {\n      if (this.calendarMainType !== CalendarTypeStringEnum.TIME) {\n        this.outputType[0] = date[0];\n        this.outputType[2] = date[1];\n        this.outputType[4] = date[2];\n        this.selectedDateTime = this.createStringFromOutput();\n      }\n    });\n  }\n\n  public setTimeValue() {\n    const dateInputArray = moment(this.dateTime).format('H/mm/A').split('/');\n    setTimeout(() => {\n      this.scrollTypes.hourScroll = this.hourTimes.indexOf(\n        parseInt(dateInputArray[0])\n      );\n      this.scrollTypes.minutesScroll = this.timeMinutes.indexOf(\n        dateInputArray[1]\n      );\n\n      this.scrollTypes.pmAmScroll = dateInputArray[2] === 'AM' ? 0 : 1;\n    });\n  }\n\n  public setListPreview(value: string): void {\n    this.listPreview = value;\n  }\n\n  public inputInFocus(): void {\n    this.isInputFocus = true;\n  }\n\n  public inputBlur(): void {\n    this.isInputFocus = false;\n  }\n\n  public changeOpened(): void {\n    // this.isInputFocus = e;\n    // if (e) {\n    if (this.calendarMainType === CalendarTypeStringEnum.TIME) {\n      setTimeout(() => {\n        this.hourScroll.nativeElement.scrollTop =\n          this.scrollTypes.hourScroll * 22;\n        this.minutesScroll.nativeElement.scrollTop =\n          this.scrollTypes.minutesScroll * 22;\n        this.pmAmScroll.nativeElement.scrollTop =\n          this.scrollTypes.pmAmScroll * 22;\n      });\n    } else {\n      let test = `${this.dateTime.getMonth() + 1\n        }/${this.dateTime.getDate()}/${this.dateTime.getFullYear()}`;\n\n      this.calendarService.scrollToDate.next(\n        `${this.dateTime.getMonth() + 1\n        }/${this.dateTime.getDate()}/${this.dateTime.getFullYear()}`\n      );\n    }\n  }\n\n  public setTime(): void {\n    this.outputType[0] = this.hourTimes[this.scrollTypes.hourScroll];\n    this.outputType[2] = this.timeMinutes[this.scrollTypes.minutesScroll];\n    this.outputType[4] = this.timeOfDay[this.scrollTypes.pmAmScroll];\n\n    this.selectedDateTime = this.createStringFromOutput();\n\n    let currentDate = moment().format('MM/DD/YYYY');\n\n    this.calendarService.dateChanged.next(\n      new Date(currentDate + ' ' + this.selectedDateTime)\n    );\n\n    this.closePopover.emit();\n  }\n\n  public setDefaultTime(): void {\n    let currentDate = moment().format('MM/DD/YYYY');\n    this.calendarService.dateChanged.next(new Date(currentDate + ' 08:00'));\n\n    this.closePopover.emit();\n  }\n\n  public closePopup(): void {\n    this.closePopover.emit();\n  }\n\n  public createStringFromOutput(): string {\n    return this.outputType.join('');\n  }\n\n  public onScroll(\n    event: Event,\n    type: keyof ScrollType,\n    index: number | null = null\n  ): void {\n    const scrolFromTop = Math.floor((event.target as HTMLElement).scrollTop);\n    const scrollIndex = index === null ? Math.floor(scrolFromTop / 22) : index;\n    const scrollRemaining = scrolFromTop % 22;\n    clearInterval(this.scrollTimer);\n    this.scrollTimer = setTimeout(() => {\n      if (scrollRemaining < 11 && index === null) {\n        (event.target as HTMLElement).scrollTop = scrollIndex * 22;\n        this.scrollTypes[type] = scrollIndex;\n      } else if (index !== null) {\n        (<HTMLElement>(<HTMLElement>event.target).parentNode).scrollTop =\n          scrollIndex * 22;\n        this.scrollTypes[type] = scrollIndex;\n      } else {\n        (event.target as HTMLElement).scrollTop = (scrollIndex + 1) * 22;\n        this.scrollTypes[type] = scrollIndex + 1;\n      }\n\n      this.checkForScrolledType(type);\n    }, 200);\n  }\n\n  public checkForScrolledType(type: string): void {\n    if (type === CalendarScrollTypeStringEnum.HOURS_SCROLL) {\n      if (this.scrollTypes[type] >= 12) {\n        this.pmAmScroll.nativeElement.scrollTop = 22;\n        this.scrollTypes.pmAmScroll = 1;\n      } else {\n        this.pmAmScroll.nativeElement.scrollTop = 0;\n        this.scrollTypes.pmAmScroll = 0;\n      }\n    }\n\n    if (type === CalendarScrollTypeStringEnum.PM_AM_SCROLL) {\n      if (this.scrollTypes[type] === 0) {\n        if (this.scrollTypes.hourScroll >= 12) {\n          this.hourScroll.nativeElement.scrollTop =\n            (this.scrollTypes.hourScroll - 12) * 22;\n          this.scrollTypes.hourScroll = Math.floor(\n            this.scrollTypes.hourScroll - 12\n          );\n        }\n      } else {\n        if (this.scrollTypes.hourScroll < 12) {\n          this.hourScroll.nativeElement.scrollTop =\n            (this.scrollTypes.hourScroll + 12) * 22;\n          this.scrollTypes.hourScroll = Math.floor(\n            this.scrollTypes.hourScroll + 12\n          );\n        }\n      }\n    }\n\n    this.selectedTime = `${this.hourTimes[this.scrollTypes.hourScroll]}:${this.timeMinutes[this.scrollTypes.minutesScroll]\n      } ${this.timeOfDay[this.scrollTypes.pmAmScroll]}`;\n  }\n\n\n  ngOnDestroy() {\n    this.listPreview = CalendarListPreviewStringEnum.FULL_LIST;\n  }\n}\n","<div class=\"temp_inp_holder\">\n    <div>\n        <div class=\"pickers_holder dark_picker\">\n            @if (calendarMainType === 'date') {\n                <div class=\"date_picker\">\n                    <app-ca-custom-datetime-pickers-date-calendars\n                        [listPreview]=\"listPreview\"\n                        [dateTime]=\"dateTime\"\n                        [isMonthAndYearOnly]=\"\n                            _inputConfig.name === 'datepickerBankCard'\n                        \"\n                        (setListPreviewValue)=\"setListPreview($event)\"\n                    ></app-ca-custom-datetime-pickers-date-calendars>\n                </div>\n            }\n            @if (calendarMainType === 'time') {\n                <div class=\"time_picker\">\n                    <div class=\"time_picker_head d-flex\">\n                        <div class=\"selected_time ta-font-bold\">\n                            {{ selectedTime }}\n                        </div>\n                        <div\n                            class=\"sel_now ta-font-bold\"\n                            (click)=\"setDefaultTime()\"\n                        >\n                            Default\n                        </div>\n                    </div>\n                    <div class=\"time_picker_body\">\n                        <div class=\"picker_body_head\">\n                            <div\n                                class=\"ta-font-bold\"\n                                [class.active]=\"hoveredItem === 'hours'\"\n                            >\n                                Hour\n                            </div>\n                            <div\n                                class=\"ta-font-bold\"\n                                [class.active]=\"hoveredItem === 'minutes'\"\n                            >\n                                Minute\n                            </div>\n                            <div\n                                class=\"ta-font-bold\"\n                                [class.active]=\"hoveredItem === 'times'\"\n                            >\n                                AM/PM\n                            </div>\n                        </div>\n                        <div class=\"picker_body\">\n                            <div\n                                #hourScroll\n                                (mouseout)=\"hoveredItem = null\"\n                                (mouseover)=\"hoveredItem = 'hours'\"\n                                (scroll)=\"onScroll($event, 'hourScroll')\"\n                                class=\"scroll_pickers\"\n                            >\n                                @for (\n                                    hour of hourTimes;\n                                    let indx = $index;\n                                    track indx\n                                ) {\n                                    <div\n                                        class=\"scroll_item ta-font-medium\"\n                                        [ngClass]=\"{\n                                            'active_item ta-font-bold':\n                                                scrollTypes.hourScroll === indx,\n                                        }\"\n                                        (click)=\"\n                                            onScroll($event, 'hourScroll', indx)\n                                        \"\n                                    >\n                                        {{ hour }}\n                                    </div>\n                                }\n                            </div>\n                            <div\n                                #minutesScroll\n                                (mouseout)=\"hoveredItem = null\"\n                                (mouseover)=\"hoveredItem = 'minutes'\"\n                                (scroll)=\"onScroll($event, 'minutesScroll')\"\n                                class=\"scroll_pickers\"\n                            >\n                                @for (\n                                    minutes of timeMinutes;\n                                    let indx = $index;\n                                    track indx\n                                ) {\n                                    <div\n                                        class=\"scroll_item ta-font-medium\"\n                                        [ngClass]=\"{\n                                            'active_item ta-font-bold':\n                                                scrollTypes.minutesScroll ===\n                                                indx,\n                                        }\"\n                                        (click)=\"\n                                            onScroll(\n                                                $event,\n                                                'minutesScroll',\n                                                indx\n                                            )\n                                        \"\n                                    >\n                                        {{ minutes }}\n                                    </div>\n                                }\n                            </div>\n                            <div\n                                #pmAmScroll\n                                (mouseout)=\"hoveredItem = null\"\n                                (mouseover)=\"hoveredItem = 'times'\"\n                                (scroll)=\"onScroll($event, 'pmAmScroll')\"\n                                class=\"scroll_pickers\"\n                            >\n                                @for (\n                                    when of timeOfDay;\n                                    let indx = $index;\n                                    track indx\n                                ) {\n                                    <div\n                                        class=\"scroll_item ta-font-medium\"\n                                        [ngClass]=\"{\n                                            'active_item ta-font-bold':\n                                                scrollTypes.pmAmScroll === indx,\n                                        }\"\n                                        (click)=\"\n                                            onScroll($event, 'pmAmScroll', indx)\n                                        \"\n                                    >\n                                        {{ when }}\n                                    </div>\n                                }\n                            </div>\n                            <div class=\"picker_line\">\n                                <span class=\"border_line\"></span>\n                                <span class=\"border_line line_2\"></span>\n                            </div>\n                        </div>\n                        <div class=\"picker_buttons\">\n                            <div\n                                (click)=\"closePopup()\"\n                                class=\"pick_button ta-font-bold\"\n                            >\n                                Cancel\n                            </div>\n                            <div\n                                (click)=\"setTime()\"\n                                class=\"pick_button set_button ta-font-bold\"\n                            >\n                                Set\n                            </div>\n                        </div>\n                    </div>\n                </div>\n            }\n        </div>\n    </div>\n</div>\n"]}
229
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-custom-datetime-pickers.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-custom-datetime-pickers/ca-custom-datetime-pickers.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-custom-datetime-pickers/ca-custom-datetime-pickers.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    OnInit,\n    Output,\n    ViewChild,\n    ViewContainerRef,\n    OnDestroy,\n    AfterViewInit,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\n\n// moment\nimport moment from 'moment';\n\n// services\nimport { CalendarDateTimePickerService } from './services/calendar-datetime-picker.service';\n\n// components\nimport { CaCustomDateTimePickersDateCalendarsComponent } from './components/ca-custom-datetime-pickers-date-calendars/ca-custom-datetime-pickers-date-calendars.component';\n\n// constants\nimport { CustomDatetimePickersConstants } from './utils/constants/custom-datetime-pickers.constants';\n\n// models\nimport { ICaInput } from '../ca-input/config/ca-input.config';\nimport { ScrollType } from './models/scroll-type.model';\n\n// enums\nimport { InputConfigNameStringEnum } from '../ca-input/enums/input-config-name-string.enum';\nimport { CalendarTypeStringEnum } from './enums/calendar-type-string.enum';\nimport { CalendarListPreviewStringEnum } from './enums/calendar-list-preview-string.enum';\nimport { CalendarScrollTypeStringEnum } from './enums/calendar-scroll-type-string.enum';\n\n@Component({\n    selector: 'ca-custom-datetime-pickers',\n    templateUrl: './ca-custom-datetime-pickers.component.html',\n    styleUrls: ['./ca-custom-datetime-pickers.component.scss'],\n    standalone: true,\n    imports: [\n        CommonModule,\n        FormsModule,\n        CaCustomDateTimePickersDateCalendarsComponent,\n    ],\n})\nexport class CaCustomDatetimePickersComponent\n    implements OnInit, OnDestroy, AfterViewInit\n{\n    @Input() dateTime!: Date;\n    @ViewChild('ref', { read: ViewContainerRef }) ref!: ViewContainerRef;\n    public _inputConfig!: ICaInput;\n    @Input() set inputConfig(config: ICaInput) {\n        this._inputConfig = config;\n        if (\n            this._inputConfig.name ===\n            InputConfigNameStringEnum.DATE_PICKER_BANK_CARD\n        )\n            this.listPreview = CalendarListPreviewStringEnum.MONTH_LIST;\n\n        if (this._inputConfig.minutesGapFive)\n            this.timeMinutes =\n                CustomDatetimePickersConstants.timeMinutesGapFive;\n        else this.timeMinutes = CustomDatetimePickersConstants.timeMinutes;\n    }\n\n    @Output() closePopover: EventEmitter<void> = new EventEmitter();\n\n    @ViewChild(CaCustomDateTimePickersDateCalendarsComponent)\n    dateCalendar!: CaCustomDateTimePickersDateCalendarsComponent;\n    @ViewChild('pmAmScroll') pmAmScroll!: ElementRef;\n    @ViewChild('minutesScroll') minutesScroll!: ElementRef;\n    @ViewChild('hourScroll') hourScroll!: ElementRef;\n\n    public selectedDateTime!: string;\n    public calendarMainType!: string;\n    public outputType!: (string | number)[];\n    public currentYear: number = new Date().getFullYear();\n    public currentMonth: number = new Date().getMonth();\n    public currentDay: number = new Date().getDate();\n    public listPreview: string = CalendarListPreviewStringEnum.FULL_LIST;\n    public timeMinutes!: string[];\n    public monthArray: number[] = new Array(12)\n        .fill(0)\n        .map((_, indx) => indx + 1);\n    public monthDayList: number[] = new Array(31)\n        .fill(0)\n        .map((_, indx) => indx + 1);\n    public yearsList: (string | number)[] = new Array(100)\n        .fill(0)\n        .map((_, idx) => (idx < 10 ? '0' + idx : idx));\n    public scrollTimer!: ReturnType<typeof setTimeout> | number;\n    public hoveredItem!: string | null;\n    public isInputFocus!: boolean;\n    public monthNames: string[] = CustomDatetimePickersConstants.monthNames;\n    public hourTimes: number[] = CustomDatetimePickersConstants.hourTimes;\n    public scrollTypes: ScrollType =\n        CustomDatetimePickersConstants.defaultScrollTypes;\n    public selectedTime: string =\n        CustomDatetimePickersConstants.defaultSelectedTime;\n    public timeOfDay: string[] = CustomDatetimePickersConstants.timeOfDay;\n\n    public previousRangeSide!: boolean;\n\n    constructor(private calendarService: CalendarDateTimePickerService) {}\n\n    @Input()\n    set calendarType(calendarType: string) {\n        this.calendarMainType = calendarType;\n        if (calendarType === CalendarTypeStringEnum.TIME)\n            this.outputType =\n                CustomDatetimePickersConstants.defaultOutputTypeTime;\n        else\n            this.outputType =\n                CustomDatetimePickersConstants.defaultOutputTypeDate;\n    }\n\n    @Input()\n    set placeholder(placeholder: string) {\n        this.selectedDateTime = placeholder;\n    }\n\n    ngOnInit(): void {\n        console.log(this.dateTime, ' this. dadateTime');\n        this.initDateChangedListener();\n    }\n\n    ngAfterViewInit(): void {\n        this.setTimeValue();\n        this.changeOpened();\n    }\n\n    public initDateChangedListener(): void {\n        this.calendarService.dateChanged.subscribe((date) => {\n            if (this.calendarMainType !== CalendarTypeStringEnum.TIME) {\n                this.outputType[0] = date[0];\n                this.outputType[2] = date[1];\n                this.outputType[4] = date[2];\n                this.selectedDateTime = this.createStringFromOutput();\n            }\n        });\n    }\n\n    public setTimeValue() {\n        const dateInputArray = moment(this.dateTime)\n            .format('H/mm/A')\n            .split('/');\n        setTimeout(() => {\n            this.scrollTypes.hourScroll = this.hourTimes.indexOf(\n                parseInt(dateInputArray[0])\n            );\n            this.scrollTypes.minutesScroll = this.timeMinutes.indexOf(\n                dateInputArray[1]\n            );\n\n            this.scrollTypes.pmAmScroll = dateInputArray[2] === 'AM' ? 0 : 1;\n        });\n    }\n\n    public setListPreview(value: string): void {\n        this.listPreview = value;\n    }\n\n    public inputInFocus(): void {\n        this.isInputFocus = true;\n    }\n\n    public inputBlur(): void {\n        this.isInputFocus = false;\n    }\n\n    public changeOpened(): void {\n        // this.isInputFocus = e;\n        // if (e) {\n        if (this.calendarMainType === CalendarTypeStringEnum.TIME) {\n            setTimeout(() => {\n                this.hourScroll.nativeElement.scrollTop =\n                    this.scrollTypes.hourScroll * 22;\n                this.minutesScroll.nativeElement.scrollTop =\n                    this.scrollTypes.minutesScroll * 22;\n                this.pmAmScroll.nativeElement.scrollTop =\n                    this.scrollTypes.pmAmScroll * 22;\n            });\n        } else {\n            let test = `${\n                this.dateTime.getMonth() + 1\n            }/${this.dateTime.getDate()}/${this.dateTime.getFullYear()}`;\n\n            this.calendarService.scrollToDate.next(\n                `${\n                    this.dateTime.getMonth() + 1\n                }/${this.dateTime.getDate()}/${this.dateTime.getFullYear()}`\n            );\n        }\n    }\n\n    public setTime(): void {\n        this.outputType[0] = this.hourTimes[this.scrollTypes.hourScroll];\n        this.outputType[2] = this.timeMinutes[this.scrollTypes.minutesScroll];\n        this.outputType[4] = this.timeOfDay[this.scrollTypes.pmAmScroll];\n\n        this.selectedDateTime = this.createStringFromOutput();\n\n        let currentDate = moment().format('MM/DD/YYYY');\n\n        this.calendarService.dateChanged.next(\n            new Date(currentDate + ' ' + this.selectedDateTime)\n        );\n\n        this.closePopover.emit();\n    }\n\n    public setDefaultTime(): void {\n        let currentDate = moment().format('MM/DD/YYYY');\n        this.calendarService.dateChanged.next(new Date(currentDate + ' 08:00'));\n\n        this.closePopover.emit();\n    }\n\n    public closePopup(): void {\n        this.closePopover.emit();\n    }\n\n    public createStringFromOutput(): string {\n        return this.outputType.join('');\n    }\n\n    public onScroll(\n        event: Event,\n        type: keyof ScrollType,\n        index: number | null = null\n    ): void {\n        const scrolFromTop = Math.floor(\n            (event.target as HTMLElement).scrollTop\n        );\n        const scrollIndex =\n            index === null ? Math.floor(scrolFromTop / 22) : index;\n        const scrollRemaining = scrolFromTop % 22;\n        clearInterval(this.scrollTimer);\n        this.scrollTimer = setTimeout(() => {\n            if (scrollRemaining < 11 && index === null) {\n                (event.target as HTMLElement).scrollTop = scrollIndex * 22;\n                this.scrollTypes[type] = scrollIndex;\n            } else if (index !== null) {\n                (<HTMLElement>(\n                    (<HTMLElement>event.target).parentNode\n                )).scrollTop = scrollIndex * 22;\n                this.scrollTypes[type] = scrollIndex;\n            } else {\n                (event.target as HTMLElement).scrollTop =\n                    (scrollIndex + 1) * 22;\n                this.scrollTypes[type] = scrollIndex + 1;\n            }\n\n            this.checkForScrolledType(type);\n        }, 200);\n    }\n\n    public checkForScrolledType(type: string): void {\n        if (type === CalendarScrollTypeStringEnum.HOURS_SCROLL) {\n            if (this.scrollTypes[type] >= 12) {\n                this.pmAmScroll.nativeElement.scrollTop = 22;\n                this.scrollTypes.pmAmScroll = 1;\n            } else {\n                this.pmAmScroll.nativeElement.scrollTop = 0;\n                this.scrollTypes.pmAmScroll = 0;\n            }\n        }\n\n        if (type === CalendarScrollTypeStringEnum.PM_AM_SCROLL) {\n            if (this.scrollTypes[type] === 0) {\n                if (this.scrollTypes.hourScroll >= 12) {\n                    this.hourScroll.nativeElement.scrollTop =\n                        (this.scrollTypes.hourScroll - 12) * 22;\n                    this.scrollTypes.hourScroll = Math.floor(\n                        this.scrollTypes.hourScroll - 12\n                    );\n                }\n            } else {\n                if (this.scrollTypes.hourScroll < 12) {\n                    this.hourScroll.nativeElement.scrollTop =\n                        (this.scrollTypes.hourScroll + 12) * 22;\n                    this.scrollTypes.hourScroll = Math.floor(\n                        this.scrollTypes.hourScroll + 12\n                    );\n                }\n            }\n        }\n\n        this.selectedTime = `${this.hourTimes[this.scrollTypes.hourScroll]}:${\n            this.timeMinutes[this.scrollTypes.minutesScroll]\n        } ${this.timeOfDay[this.scrollTypes.pmAmScroll]}`;\n    }\n\n    ngOnDestroy() {\n        this.listPreview = CalendarListPreviewStringEnum.FULL_LIST;\n    }\n}\n","<div class=\"temp_inp_holder\">\n    <div>\n        <div class=\"pickers_holder dark_picker\">\n            @if (calendarMainType === 'date') {\n                <div class=\"date_picker\">\n                    <app-ca-custom-datetime-pickers-date-calendars\n                        [listPreview]=\"listPreview\"\n                        [dateTime]=\"dateTime\"\n                        [isMonthAndYearOnly]=\"\n                            _inputConfig.name === 'datepickerBankCard'\n                        \"\n                        (setListPreviewValue)=\"setListPreview($event)\"\n                    ></app-ca-custom-datetime-pickers-date-calendars>\n                </div>\n            }\n            @if (calendarMainType === 'time') {\n                <div class=\"time_picker\">\n                    <div class=\"time_picker_head d-flex\">\n                        <div class=\"selected_time ta-font-bold\">\n                            {{ selectedTime }}\n                        </div>\n                        <div\n                            class=\"sel_now ta-font-bold\"\n                            (click)=\"setDefaultTime()\"\n                        >\n                            Default\n                        </div>\n                    </div>\n                    <div class=\"time_picker_body\">\n                        <div class=\"picker_body_head\">\n                            <div\n                                class=\"ta-font-bold\"\n                                [class.active]=\"hoveredItem === 'hours'\"\n                            >\n                                Hour\n                            </div>\n                            <div\n                                class=\"ta-font-bold\"\n                                [class.active]=\"hoveredItem === 'minutes'\"\n                            >\n                                Minute\n                            </div>\n                            <div\n                                class=\"ta-font-bold\"\n                                [class.active]=\"hoveredItem === 'times'\"\n                            >\n                                AM/PM\n                            </div>\n                        </div>\n                        <div class=\"picker_body\">\n                            <div\n                                #hourScroll\n                                (mouseout)=\"hoveredItem = null\"\n                                (mouseover)=\"hoveredItem = 'hours'\"\n                                (scroll)=\"onScroll($event, 'hourScroll')\"\n                                class=\"scroll_pickers\"\n                            >\n                                @for (\n                                    hour of hourTimes;\n                                    let indx = $index;\n                                    track indx\n                                ) {\n                                    <div\n                                        class=\"scroll_item ta-font-medium\"\n                                        [ngClass]=\"{\n                                            'active_item ta-font-bold':\n                                                scrollTypes.hourScroll === indx,\n                                        }\"\n                                        (click)=\"\n                                            onScroll($event, 'hourScroll', indx)\n                                        \"\n                                    >\n                                        {{ hour }}\n                                    </div>\n                                }\n                            </div>\n                            <div\n                                #minutesScroll\n                                (mouseout)=\"hoveredItem = null\"\n                                (mouseover)=\"hoveredItem = 'minutes'\"\n                                (scroll)=\"onScroll($event, 'minutesScroll')\"\n                                class=\"scroll_pickers\"\n                            >\n                                @for (\n                                    minutes of timeMinutes;\n                                    let indx = $index;\n                                    track indx\n                                ) {\n                                    <div\n                                        class=\"scroll_item ta-font-medium\"\n                                        [ngClass]=\"{\n                                            'active_item ta-font-bold':\n                                                scrollTypes.minutesScroll ===\n                                                indx,\n                                        }\"\n                                        (click)=\"\n                                            onScroll(\n                                                $event,\n                                                'minutesScroll',\n                                                indx\n                                            )\n                                        \"\n                                    >\n                                        {{ minutes }}\n                                    </div>\n                                }\n                            </div>\n                            <div\n                                #pmAmScroll\n                                (mouseout)=\"hoveredItem = null\"\n                                (mouseover)=\"hoveredItem = 'times'\"\n                                (scroll)=\"onScroll($event, 'pmAmScroll')\"\n                                class=\"scroll_pickers\"\n                            >\n                                @for (\n                                    when of timeOfDay;\n                                    let indx = $index;\n                                    track indx\n                                ) {\n                                    <div\n                                        class=\"scroll_item ta-font-medium\"\n                                        [ngClass]=\"{\n                                            'active_item ta-font-bold':\n                                                scrollTypes.pmAmScroll === indx,\n                                        }\"\n                                        (click)=\"\n                                            onScroll($event, 'pmAmScroll', indx)\n                                        \"\n                                    >\n                                        {{ when }}\n                                    </div>\n                                }\n                            </div>\n                            <div class=\"picker_line\">\n                                <span class=\"border_line\"></span>\n                                <span class=\"border_line line_2\"></span>\n                            </div>\n                        </div>\n                        <div class=\"picker_buttons\">\n                            <div\n                                (click)=\"closePopup()\"\n                                class=\"pick_button ta-font-bold\"\n                            >\n                                Cancel\n                            </div>\n                            <div\n                                (click)=\"setTime()\"\n                                class=\"pick_button set_button ta-font-bold\"\n                            >\n                                Set\n                            </div>\n                        </div>\n                    </div>\n                </div>\n            }\n        </div>\n    </div>\n</div>\n"]}
@@ -56,7 +56,8 @@ export class CaCustomDateTimePickerCalendarDatesMainComponent {
56
56
  .pipe(takeUntil(this.destroy$))
57
57
  .subscribe((res) => {
58
58
  if (res.type !== CalendarStringEnum.MAIN &&
59
- this.calendarService.selectedScroll !== CalendarStringEnum.MAIN) {
59
+ this.calendarService.selectedScroll !==
60
+ CalendarStringEnum.MAIN) {
60
61
  const sizeTimes = CalendarMainStringEnum.FULL_SIZE / res.cycleSize;
61
62
  const newScrollSize = Math.ceil(sizeTimes * res.scrollOffset);
62
63
  this.scrollStrategy.scrollToOffset(newScrollSize, CalendarStringEnum.AUTO);
@@ -93,7 +94,8 @@ export class CaCustomDateTimePickerCalendarDatesMainComponent {
93
94
  onMonthChange(data) {
94
95
  if (this.months[data.indx]) {
95
96
  this.selectedYear = this.months[data.indx].getFullYear();
96
- this.selectedMonth = this.monthNames[this.months[data.indx].getMonth()];
97
+ this.selectedMonth =
98
+ this.monthNames[this.months[data.indx].getMonth()];
97
99
  this.activeMonth = data.indx;
98
100
  this.calendarService.index$.next(data);
99
101
  }
@@ -173,4 +175,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
173
175
  }], setAutoIndex: [{
174
176
  type: Output
175
177
  }] } });
176
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-custom-datetime-pickers-calendar-dates-main.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ca-components/src/lib/components/ca-custom-datetime-pickers/components/ca-custom-datetime-pickers-calendar-dates-main/ca-custom-datetime-pickers-calendar-dates-main.component.ts","../../../../../../../../projects/ca-components/src/lib/components/ca-custom-datetime-pickers/components/ca-custom-datetime-pickers-calendar-dates-main/ca-custom-datetime-pickers-calendar-dates-main.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  OnDestroy,\n  forwardRef,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { Subject, takeUntil } from 'rxjs';\n\n// modules\nimport {\n  ScrollingModule,\n  VIRTUAL_SCROLL_STRATEGY,\n} from '@angular/cdk/scrolling';\n\n// moment\nimport moment from 'moment';\n\n// services\nimport { CalendarDateTimePickerService } from '../../services/calendar-datetime-picker.service';\n\n// components\nimport { CaCustomDateTimePickersCalendarDaysComponent } from '../ca-custom-datetime-pickers-calendar-days/ca-custom-datetime-pickers-calendar-days.component';\n\n// strategy\nimport {\n  CalendarStrategy,\n  STARTING_YEAR,\n} from '../../strategy/calendar-strategy';\n\n// enums\nimport { CalendarMainStringEnum } from '../../enums/calendar-main-string.enum';\nimport { CalendarStringEnum } from '../../enums/calendar-string.enum';\nimport { CalendarListPreviewStringEnum } from '../../enums/calendar-list-preview-string.enum';\nimport { CustomDatetimePickersConstants } from '../../utils/constants/custom-datetime-pickers.constants';\n\nfunction factory(dir: CaCustomDateTimePickerCalendarDatesMainComponent) {\n  return dir.scrollStrategy;\n}\n\n@Component({\n  selector: 'app-ca-custom-datetime-pickers--calendar-dates-main',\n  templateUrl:\n    './ca-custom-datetime-pickers-calendar-dates-main.component.html',\n  styleUrls: [\n    './ca-custom-datetime-pickers-calendar-dates-main.component.scss',\n  ],\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ScrollingModule,\n    CaCustomDateTimePickersCalendarDaysComponent,\n  ],\n  providers: [\n    {\n      provide: VIRTUAL_SCROLL_STRATEGY,\n      useFactory: factory,\n      deps: [\n        forwardRef(() => CaCustomDateTimePickerCalendarDatesMainComponent),\n      ],\n    },\n  ],\n})\nexport class CaCustomDateTimePickerCalendarDatesMainComponent\n  implements OnInit, OnDestroy\n{\n  @Input() months!: Date[];\n  @Input() dateTime!: Date;\n  @Input() currentIndex!: number;\n  @Input() currentYearIndex!: number;\n  @Input() activeIndex!: number;\n  @Input() monthYearsIndx!: string[];\n\n  public _listPreview!: string;\n  @Input() set listPreview(value: string) {\n    this._listPreview = value;\n    this.scrollStrategy.updateScrollHeights(\n      value === CalendarListPreviewStringEnum.MONTH_LIST\n        ? CalendarMainStringEnum.CYCLE_HEIGHT_BY_MONTHS\n        : CalendarMainStringEnum.CYCLE_HEIGHT\n    );\n  }\n  @Input() isMonthAndYearOnly!: boolean;\n  @Output() setListPreviewToFull: EventEmitter<number> = new EventEmitter();\n  @Output() setAutoIndex: EventEmitter<number> = new EventEmitter();\n\n  public scrollStrategy: CalendarStrategy = new CalendarStrategy(\n    this.calendarService,\n    CalendarMainStringEnum.CYCLE_HEIGHT,\n    CalendarMainStringEnum.FULL_SIZE,\n    CalendarStringEnum.MAIN\n  );\n\n  private destroy$ = new Subject<void>();\n\n  public monthNames = CustomDatetimePickersConstants.monthNames;\n\n  public selectedYear!: number;\n  public selectedYearFromInput!: number;\n  public selMonth!: number;\n  public selectedMonth!: string;\n  private activeMonth = 0;\n\n  constructor(private calendarService: CalendarDateTimePickerService) {}\n\n  ngOnInit(): void {\n    this.initScrollListeners();\n  }\n\n  public initScrollListeners(): void {\n    this.selMonth = this.dateTime.getMonth();\n    this.selectedYearFromInput = this.dateTime.getFullYear();\n    //this.selectedYearFromInput = this.months.getFullYear();\n\n    this.calendarService.scrollToAutoIndex\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((indx) => {\n        setTimeout(() => {\n          this.scrollStrategy.scrollToIndex(indx, CalendarStringEnum.AUTO);\n        });\n      });\n\n    this.calendarService.scrolledIndexChange\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((res) => {\n        if (\n          res.type !== CalendarStringEnum.MAIN &&\n          this.calendarService.selectedScroll !== CalendarStringEnum.MAIN\n        ) {\n          const sizeTimes = CalendarMainStringEnum.FULL_SIZE / res.cycleSize;\n          const newScrollSize = Math.ceil(sizeTimes * res.scrollOffset);\n          this.scrollStrategy.scrollToOffset(\n            newScrollSize,\n            CalendarStringEnum.AUTO\n          );\n        }\n      });\n\n    this.calendarService.scrollToDate\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((res) => {\n        setTimeout(() => {\n          if (res) {\n            const indx = this.findIndexInMonth(res);\n            this.scrollStrategy.scrollToIndex(indx, CalendarStringEnum.AUTO);\n          } else {\n            this.scrollStrategy.scrollToIndex(\n              this.currentIndex,\n              CalendarStringEnum.AUTO\n            );\n          }\n        }, 200);\n      });\n\n    if (this.isMonthAndYearOnly) {\n      setTimeout(() => {\n        this.scrollStrategy.updateScrollHeights(\n          CalendarMainStringEnum.CYCLE_HEIGHT_BY_MONTHS\n        );\n\n        setTimeout(() => {\n          this.scrollStrategy.scrollToIndex(\n            this.currentYearIndex,\n            CalendarStringEnum.AUTO\n          );\n        }, 200);\n      }, 200);\n    }\n  }\n\n  public findIndexInMonth(date: string): number {\n    const selectedDate = new Date(date);\n    const indexMonth = (selectedDate.getFullYear() - STARTING_YEAR) * 12;\n    const indx = indexMonth + selectedDate.getMonth();\n    return indx;\n  }\n\n  public onMonthChange(data: any): void {\n    if (this.months[data.indx]) {\n      this.selectedYear = this.months[data.indx].getFullYear();\n      this.selectedMonth = this.monthNames[this.months[data.indx].getMonth()];\n      this.activeMonth = data.indx;\n      this.calendarService.index$.next(data);\n    }\n  }\n\n  public getMonth(index: number): string {\n    return CustomDatetimePickersConstants.monthNames[index];\n  }\n\n  public mouseOverSetItem() {\n    this.calendarService.scrolledScrollItem = CalendarStringEnum.MAIN;\n  }\n\n  public setCalendarListPreview(num: number, index: number): void {\n    this.selMonth = num;\n\n    if (this.isMonthAndYearOnly) {\n      this.setAutoIndex.emit(num);\n\n      const selectedMonth = this.months[index];\n      const new_date = moment(\n        new Date(selectedMonth.getFullYear(), num + 1, 0)\n      ).format();\n      this.calendarService.dateChanged.next(new_date);\n    } else {\n      this.setListPreviewToFull.emit(num);\n    }\n  }\n\n  public selectDay(data: { day: number; index: number }): void {\n    const selectedMonth = this.months[data.index];\n    const new_date = moment(\n      new Date(selectedMonth.getFullYear(), selectedMonth.getMonth(), data.day)\n    ).format();\n    this.calendarService.dateChanged.next(new_date);\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n","<div (mouseover)=\"mouseOverSetItem()\">\n    <cdk-virtual-scroll-viewport\n        #monthsScrollRef\n        (scrolledIndexChange)=\"onMonthChange($event)\"\n        style=\"height: 200px; width: 100%; margin: 0\"\n    >\n        <ng-container\n            *cdkVirtualFor=\"\n                let month of months;\n                let indx = index;\n                templateCacheSize: 10\n            \"\n        >\n            <div\n                class=\"calendar_indicator ta-font-bold\"\n                [class.full_calendar]=\"_listPreview === 'full_list'\"\n                [class.current_year]=\"\n                    isMonthAndYearOnly\n                        ? selectedYearFromInput === month.getFullYear()\n                        : selectedYearFromInput === month.getFullYear() &&\n                          selMonth === month.getMonth()\n                \"\n            >\n                @if (_listPreview === 'full_list') {\n                    <span>{{ getMonth(month.getMonth()) }} </span>\n                }\n                {{ month.getFullYear() }}\n            </div>\n            @if (_listPreview === 'full_list') {\n                <div>\n                    <app-ca-custom-datetime-picker-calendar-days\n                        (selectDay)=\"selectDay($event)\"\n                        [index]=\"indx\"\n                        [month]=\"month\"\n                        [selectedMonth]=\"month.getMonth()\"\n                        [year]=\"selectedYear\"\n                        [dateTime]=\"dateTime\"\n                        [activeMonth]=\"\n                            selectedYearFromInput === month.getFullYear() &&\n                            selMonth === month.getMonth()\n                        \"\n                    ></app-ca-custom-datetime-picker-calendar-days>\n                </div>\n            }\n            @if (_listPreview === 'month_list') {\n                <div>\n                    <div\n                        class=\"month_list\"\n                        [class.current_year]=\"\n                            selectedYearFromInput === month.getFullYear()\n                        \"\n                    >\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(0, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 0 === selMonth,\n                            }\"\n                        >\n                            JAN\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(1, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 1 === selMonth,\n                            }\"\n                        >\n                            FEB\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(2, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 2 === selMonth,\n                            }\"\n                        >\n                            MAR\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(3, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 3 === selMonth,\n                            }\"\n                        >\n                            APR\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(4, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 4 === selMonth,\n                            }\"\n                        >\n                            MAY\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(5, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 5 === selMonth,\n                            }\"\n                        >\n                            JUN\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(6, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 6 === selMonth,\n                            }\"\n                        >\n                            JUL\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(7, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 7 === selMonth,\n                            }\"\n                        >\n                            AUG\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(8, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 8 === selMonth,\n                            }\"\n                        >\n                            SEP\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(9, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 9 === selMonth,\n                            }\"\n                        >\n                            OCT\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(10, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 10 === selMonth,\n                            }\"\n                        >\n                            NOV\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(11, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 11 === selMonth,\n                            }\"\n                        >\n                            DEC\n                        </div>\n                    </div>\n                </div>\n            }\n        </ng-container>\n    </cdk-virtual-scroll-viewport>\n</div>\n"]}
178
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-custom-datetime-pickers-calendar-dates-main.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ca-components/src/lib/components/ca-custom-datetime-pickers/components/ca-custom-datetime-pickers-calendar-dates-main/ca-custom-datetime-pickers-calendar-dates-main.component.ts","../../../../../../../../projects/ca-components/src/lib/components/ca-custom-datetime-pickers/components/ca-custom-datetime-pickers-calendar-dates-main/ca-custom-datetime-pickers-calendar-dates-main.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    EventEmitter,\n    Input,\n    OnInit,\n    Output,\n    OnDestroy,\n    forwardRef,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { Subject, takeUntil } from 'rxjs';\n\n// modules\nimport {\n    ScrollingModule,\n    VIRTUAL_SCROLL_STRATEGY,\n} from '@angular/cdk/scrolling';\n\n// moment\nimport moment from 'moment';\n\n// services\nimport { CalendarDateTimePickerService } from '../../services/calendar-datetime-picker.service';\n\n// components\nimport { CaCustomDateTimePickersCalendarDaysComponent } from '../ca-custom-datetime-pickers-calendar-days/ca-custom-datetime-pickers-calendar-days.component';\n\n// strategy\nimport {\n    CalendarStrategy,\n    STARTING_YEAR,\n} from '../../strategy/calendar-strategy';\n\n// enums\nimport { CalendarMainStringEnum } from '../../enums/calendar-main-string.enum';\nimport { CalendarStringEnum } from '../../enums/calendar-string.enum';\nimport { CalendarListPreviewStringEnum } from '../../enums/calendar-list-preview-string.enum';\nimport { CustomDatetimePickersConstants } from '../../utils/constants/custom-datetime-pickers.constants';\n\nfunction factory(dir: CaCustomDateTimePickerCalendarDatesMainComponent) {\n    return dir.scrollStrategy;\n}\n\n@Component({\n    selector: 'app-ca-custom-datetime-pickers--calendar-dates-main',\n    templateUrl:\n        './ca-custom-datetime-pickers-calendar-dates-main.component.html',\n    styleUrls: [\n        './ca-custom-datetime-pickers-calendar-dates-main.component.scss',\n    ],\n    standalone: true,\n    imports: [\n        CommonModule,\n        FormsModule,\n        ScrollingModule,\n        CaCustomDateTimePickersCalendarDaysComponent,\n    ],\n    providers: [\n        {\n            provide: VIRTUAL_SCROLL_STRATEGY,\n            useFactory: factory,\n            deps: [\n                forwardRef(\n                    () => CaCustomDateTimePickerCalendarDatesMainComponent\n                ),\n            ],\n        },\n    ],\n})\nexport class CaCustomDateTimePickerCalendarDatesMainComponent\n    implements OnInit, OnDestroy\n{\n    @Input() months!: Date[];\n    @Input() dateTime!: Date;\n    @Input() currentIndex!: number;\n    @Input() currentYearIndex!: number;\n    @Input() activeIndex!: number;\n    @Input() monthYearsIndx!: string[];\n\n    public _listPreview!: string;\n    @Input() set listPreview(value: string) {\n        this._listPreview = value;\n        this.scrollStrategy.updateScrollHeights(\n            value === CalendarListPreviewStringEnum.MONTH_LIST\n                ? CalendarMainStringEnum.CYCLE_HEIGHT_BY_MONTHS\n                : CalendarMainStringEnum.CYCLE_HEIGHT\n        );\n    }\n    @Input() isMonthAndYearOnly!: boolean;\n    @Output() setListPreviewToFull: EventEmitter<number> = new EventEmitter();\n    @Output() setAutoIndex: EventEmitter<number> = new EventEmitter();\n\n    public scrollStrategy: CalendarStrategy = new CalendarStrategy(\n        this.calendarService,\n        CalendarMainStringEnum.CYCLE_HEIGHT,\n        CalendarMainStringEnum.FULL_SIZE,\n        CalendarStringEnum.MAIN\n    );\n\n    private destroy$ = new Subject<void>();\n\n    public monthNames = CustomDatetimePickersConstants.monthNames;\n\n    public selectedYear!: number;\n    public selectedYearFromInput!: number;\n    public selMonth!: number;\n    public selectedMonth!: string;\n    private activeMonth = 0;\n\n    constructor(private calendarService: CalendarDateTimePickerService) {}\n\n    ngOnInit(): void {\n        this.initScrollListeners();\n    }\n\n    public initScrollListeners(): void {\n        this.selMonth = this.dateTime.getMonth();\n        this.selectedYearFromInput = this.dateTime.getFullYear();\n        //this.selectedYearFromInput = this.months.getFullYear();\n\n        this.calendarService.scrollToAutoIndex\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((indx) => {\n                setTimeout(() => {\n                    this.scrollStrategy.scrollToIndex(\n                        indx,\n                        CalendarStringEnum.AUTO\n                    );\n                });\n            });\n\n        this.calendarService.scrolledIndexChange\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((res) => {\n                if (\n                    res.type !== CalendarStringEnum.MAIN &&\n                    this.calendarService.selectedScroll !==\n                        CalendarStringEnum.MAIN\n                ) {\n                    const sizeTimes =\n                        CalendarMainStringEnum.FULL_SIZE / res.cycleSize;\n                    const newScrollSize = Math.ceil(\n                        sizeTimes * res.scrollOffset\n                    );\n                    this.scrollStrategy.scrollToOffset(\n                        newScrollSize,\n                        CalendarStringEnum.AUTO\n                    );\n                }\n            });\n\n        this.calendarService.scrollToDate\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((res) => {\n                setTimeout(() => {\n                    if (res) {\n                        const indx = this.findIndexInMonth(res);\n                        this.scrollStrategy.scrollToIndex(\n                            indx,\n                            CalendarStringEnum.AUTO\n                        );\n                    } else {\n                        this.scrollStrategy.scrollToIndex(\n                            this.currentIndex,\n                            CalendarStringEnum.AUTO\n                        );\n                    }\n                }, 200);\n            });\n\n        if (this.isMonthAndYearOnly) {\n            setTimeout(() => {\n                this.scrollStrategy.updateScrollHeights(\n                    CalendarMainStringEnum.CYCLE_HEIGHT_BY_MONTHS\n                );\n\n                setTimeout(() => {\n                    this.scrollStrategy.scrollToIndex(\n                        this.currentYearIndex,\n                        CalendarStringEnum.AUTO\n                    );\n                }, 200);\n            }, 200);\n        }\n    }\n\n    public findIndexInMonth(date: string): number {\n        const selectedDate = new Date(date);\n        const indexMonth = (selectedDate.getFullYear() - STARTING_YEAR) * 12;\n        const indx = indexMonth + selectedDate.getMonth();\n        return indx;\n    }\n\n    public onMonthChange(data: any): void {\n        if (this.months[data.indx]) {\n            this.selectedYear = this.months[data.indx].getFullYear();\n            this.selectedMonth =\n                this.monthNames[this.months[data.indx].getMonth()];\n            this.activeMonth = data.indx;\n            this.calendarService.index$.next(data);\n        }\n    }\n\n    public getMonth(index: number): string {\n        return CustomDatetimePickersConstants.monthNames[index];\n    }\n\n    public mouseOverSetItem() {\n        this.calendarService.scrolledScrollItem = CalendarStringEnum.MAIN;\n    }\n\n    public setCalendarListPreview(num: number, index: number): void {\n        this.selMonth = num;\n\n        if (this.isMonthAndYearOnly) {\n            this.setAutoIndex.emit(num);\n\n            const selectedMonth = this.months[index];\n            const new_date = moment(\n                new Date(selectedMonth.getFullYear(), num + 1, 0)\n            ).format();\n            this.calendarService.dateChanged.next(new_date);\n        } else {\n            this.setListPreviewToFull.emit(num);\n        }\n    }\n\n    public selectDay(data: { day: number; index: number }): void {\n        const selectedMonth = this.months[data.index];\n        const new_date = moment(\n            new Date(\n                selectedMonth.getFullYear(),\n                selectedMonth.getMonth(),\n                data.day\n            )\n        ).format();\n        this.calendarService.dateChanged.next(new_date);\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n","<div (mouseover)=\"mouseOverSetItem()\">\n    <cdk-virtual-scroll-viewport\n        #monthsScrollRef\n        (scrolledIndexChange)=\"onMonthChange($event)\"\n        style=\"height: 200px; width: 100%; margin: 0\"\n    >\n        <ng-container\n            *cdkVirtualFor=\"\n                let month of months;\n                let indx = index;\n                templateCacheSize: 10\n            \"\n        >\n            <div\n                class=\"calendar_indicator ta-font-bold\"\n                [class.full_calendar]=\"_listPreview === 'full_list'\"\n                [class.current_year]=\"\n                    isMonthAndYearOnly\n                        ? selectedYearFromInput === month.getFullYear()\n                        : selectedYearFromInput === month.getFullYear() &&\n                          selMonth === month.getMonth()\n                \"\n            >\n                @if (_listPreview === 'full_list') {\n                    <span>{{ getMonth(month.getMonth()) }} </span>\n                }\n                {{ month.getFullYear() }}\n            </div>\n            @if (_listPreview === 'full_list') {\n                <div>\n                    <app-ca-custom-datetime-picker-calendar-days\n                        (selectDay)=\"selectDay($event)\"\n                        [index]=\"indx\"\n                        [month]=\"month\"\n                        [selectedMonth]=\"month.getMonth()\"\n                        [year]=\"selectedYear\"\n                        [dateTime]=\"dateTime\"\n                        [activeMonth]=\"\n                            selectedYearFromInput === month.getFullYear() &&\n                            selMonth === month.getMonth()\n                        \"\n                    ></app-ca-custom-datetime-picker-calendar-days>\n                </div>\n            }\n            @if (_listPreview === 'month_list') {\n                <div>\n                    <div\n                        class=\"month_list\"\n                        [class.current_year]=\"\n                            selectedYearFromInput === month.getFullYear()\n                        \"\n                    >\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(0, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 0 === selMonth,\n                            }\"\n                        >\n                            JAN\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(1, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 1 === selMonth,\n                            }\"\n                        >\n                            FEB\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(2, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 2 === selMonth,\n                            }\"\n                        >\n                            MAR\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(3, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 3 === selMonth,\n                            }\"\n                        >\n                            APR\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(4, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 4 === selMonth,\n                            }\"\n                        >\n                            MAY\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(5, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 5 === selMonth,\n                            }\"\n                        >\n                            JUN\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(6, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 6 === selMonth,\n                            }\"\n                        >\n                            JUL\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(7, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 7 === selMonth,\n                            }\"\n                        >\n                            AUG\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(8, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 8 === selMonth,\n                            }\"\n                        >\n                            SEP\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(9, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 9 === selMonth,\n                            }\"\n                        >\n                            OCT\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(10, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 10 === selMonth,\n                            }\"\n                        >\n                            NOV\n                        </div>\n                        <div\n                            class=\"month_list_item ta-font-medium\"\n                            (click)=\"setCalendarListPreview(11, indx)\"\n                            [ngClass]=\"{\n                                'current_month ta-font-bold':\n                                    selectedYearFromInput ===\n                                        month.getFullYear() && 11 === selMonth,\n                            }\"\n                        >\n                            DEC\n                        </div>\n                    </div>\n                </div>\n            }\n        </ng-container>\n    </cdk-virtual-scroll-viewport>\n</div>\n"]}
@@ -57,4 +57,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
57
57
  }], month: [{
58
58
  type: Input
59
59
  }] } });
60
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2EtY3VzdG9tLWRhdGV0aW1lLXBpY2tlcnMtY2FsZW5kYXItZGF5cy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jYS1jdXN0b20tZGF0ZXRpbWUtcGlja2Vycy9jb21wb25lbnRzL2NhLWN1c3RvbS1kYXRldGltZS1waWNrZXJzLWNhbGVuZGFyLWRheXMvY2EtY3VzdG9tLWRhdGV0aW1lLXBpY2tlcnMtY2FsZW5kYXItZGF5cy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jYS1jdXN0b20tZGF0ZXRpbWUtcGlja2Vycy9jb21wb25lbnRzL2NhLWN1c3RvbS1kYXRldGltZS1waWNrZXJzLWNhbGVuZGFyLWRheXMvY2EtY3VzdG9tLWRhdGV0aW1lLXBpY2tlcnMtY2FsZW5kYXItZGF5cy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMvRSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQVM3QyxNQUFNLE9BQU8sNENBQTRDO0lBaUJ2RCxJQUNJLEtBQUssQ0FBQyxLQUFXO1FBQ25CLElBQUksQ0FBQyxzQkFBc0IsR0FBRyxRQUFRLENBQ3BDLENBQUMsR0FBRyxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FDdkMsQ0FBQztRQUNGLElBQUksQ0FBQyxxQkFBcUIsR0FBRyxLQUFLLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDakQsTUFBTSxXQUFXLEdBQUcsS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ25DLE1BQU0sT0FBTyxHQUFHLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLEVBQUUsRUFBRSxLQUFLLENBQUMsUUFBUSxFQUFFLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3ZFLE1BQU0sU0FBUyxHQUFHLE9BQU8sQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUVwQyxJQUFJLENBQUMsSUFBSSxHQUFHO1lBQ1YsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUUsTUFBTSxFQUFFLFdBQVcsRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLEVBQUUsQ0FBQztZQUNwRCxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1NBQzFELENBQUM7SUFDSixDQUFDO0lBRUQ7UUEzQlUsY0FBUyxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7UUFDbEMsZ0JBQVcsR0FBVyxJQUFJLElBQUksRUFBRSxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBQy9DLGlCQUFZLEdBQVcsSUFBSSxJQUFJLEVBQUUsQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUM3QyxlQUFVLEdBQVcsSUFBSSxJQUFJLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUcxQyxTQUFJLEdBQW1DLEVBQUUsQ0FBQztRQUMxQyxnQkFBVyxHQUFXLENBQUMsQ0FBQyxDQUFDO1FBQ3pCLGFBQVEsR0FBVyxDQUFDLENBQUMsQ0FBQztRQUN0QixpQkFBWSxHQUFXLENBQUMsQ0FBQyxDQUFDO0lBa0JqQixDQUFDO0lBRWpCLFFBQVE7UUFDTixJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUVNLFNBQVMsQ0FBQyxHQUFvQjtRQUNuQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUM7SUFDbEQsQ0FBQztJQUVPLGVBQWU7UUFDckIsSUFBSSxDQUFDLFdBQVcsR0FBRyxRQUFRLENBQUMsQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDdkUsSUFBSSxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUMsQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3pFLElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUNsRCxDQUFDOytHQS9DVSw0Q0FBNEM7bUdBQTVDLDRDQUE0Qyx3UkNYekQsd3pCQXVCQSx5RERkWSxZQUFZLDRIQUFFLFdBQVc7OzRGQUV4Qiw0Q0FBNEM7a0JBUHhELFNBQVM7K0JBQ0UsNkNBQTZDLGNBRzNDLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSxXQUFXLENBQUM7d0RBRzNCLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUs7Z0JBQ0ksU0FBUztzQkFBbEIsTUFBTTtnQkFZSCxLQUFLO3NCQURSLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FwcC1jYS1jdXN0b20tZGF0ZXRpbWUtcGlja2VyLWNhbGVuZGFyLWRheXMnLFxuICB0ZW1wbGF0ZVVybDogJy4vY2EtY3VzdG9tLWRhdGV0aW1lLXBpY2tlcnMtY2FsZW5kYXItZGF5cy5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2NhLWN1c3RvbS1kYXRldGltZS1waWNrZXJzLWNhbGVuZGFyLWRheXMuY29tcG9uZW50LnNjc3MnXSxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGVdLFxufSlcbmV4cG9ydCBjbGFzcyBDYUN1c3RvbURhdGVUaW1lUGlja2Vyc0NhbGVuZGFyRGF5c0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIEBJbnB1dCgpIGRhdGVUaW1lITogRGF0ZTtcbiAgQElucHV0KCkgeWVhciE6IG51bWJlcjtcbiAgQElucHV0KCkgc2VsZWN0ZWRNb250aCE6IHN0cmluZztcbiAgQElucHV0KCkgaW5kZXghOiBudW1iZXI7XG4gIEBJbnB1dCgpIGFjdGl2ZU1vbnRoITogYm9vbGVhbjtcbiAgQE91dHB1dCgpIHNlbGVjdERheSA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcbiAgcHVibGljIGN1cnJlbnRZZWFyOiBudW1iZXIgPSBuZXcgRGF0ZSgpLmdldEZ1bGxZZWFyKCk7XG4gIHB1YmxpYyBjdXJyZW50TW9udGg6IG51bWJlciA9IG5ldyBEYXRlKCkuZ2V0TW9udGgoKTtcbiAgcHVibGljIGN1cnJlbnREYXk6IG51bWJlciA9IG5ldyBEYXRlKCkuZ2V0RGF0ZSgpO1xuICBwdWJsaWMgc2VsZWN0ZWRNb250aEZyb21JbnB1dCE6IG51bWJlcjtcbiAgcHVibGljIHNlbGVjdGVkWWVhckZyb21JbnB1dCE6IG51bWJlcjtcbiAgcHVibGljIGRheXM6IFJlYWRvbmx5QXJyYXk8c3RyaW5nIHwgbnVtYmVyPiA9IFtdO1xuICBwdWJsaWMgc2VsZWN0ZWREYXk6IG51bWJlciA9IC0xO1xuICBwdWJsaWMgc2VsTW9udGg6IG51bWJlciA9IC0xO1xuICBwdWJsaWMgc2VsZWN0ZWRZZWFyOiBudW1iZXIgPSAtMTtcblxuICBASW5wdXQoKVxuICBzZXQgbW9udGgobW9udGg6IERhdGUpIHtcbiAgICB0aGlzLnNlbGVjdGVkTW9udGhGcm9tSW5wdXQgPSBwYXJzZUludChcbiAgICAgICgnMCcgKyBtb250aC5nZXRNb250aCgpICsgMSkuc2xpY2UoLTIpXG4gICAgKTtcbiAgICB0aGlzLnNlbGVjdGVkWWVhckZyb21JbnB1dCA9IG1vbnRoLmdldEZ1bGxZZWFyKCk7XG4gICAgY29uc3QgZmlsbGVyQ291bnQgPSBtb250aC5nZXREYXkoKTtcbiAgICBjb25zdCBsYXN0RGF5ID0gbmV3IERhdGUobW9udGguZ2V0RnVsbFllYXIoKSwgbW9udGguZ2V0TW9udGgoKSArIDEsIDApO1xuICAgIGNvbnN0IGRheXNDb3VudCA9IGxhc3REYXkuZ2V0RGF0ZSgpO1xuXG4gICAgdGhpcy5kYXlzID0gW1xuICAgICAgLi4uQXJyYXkuZnJvbSh7IGxlbmd0aDogZmlsbGVyQ291bnQgfSkubWFwKCgpID0+ICcnKSxcbiAgICAgIC4uLkFycmF5LmZyb20oeyBsZW5ndGg6IGRheXNDb3VudCB9KS5tYXAoKF8sIGkpID0+IGkgKyAxKSxcbiAgICBdO1xuICB9XG5cbiAgY29uc3RydWN0b3IoKSB7IH1cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLnNldFNlbGVjdGVkRGF0ZSgpO1xuICB9XG5cbiAgcHVibGljIGNob29zZURheShkYXk6IG51bWJlciB8IHN0cmluZyk6IHZvaWQge1xuICAgIHRoaXMuc2VsZWN0RGF5LmVtaXQoeyBpbmRleDogdGhpcy5pbmRleCwgZGF5IH0pO1xuICB9XG5cbiAgcHJpdmF0ZSBzZXRTZWxlY3RlZERhdGUoKTogdm9pZCB7XG4gICAgdGhpcy5zZWxlY3RlZERheSA9IHBhcnNlSW50KCgnMCcgKyB0aGlzLmRhdGVUaW1lLmdldERhdGUoKSkuc2xpY2UoLTIpKTtcbiAgICB0aGlzLnNlbE1vbnRoID0gcGFyc2VJbnQoKCcwJyArIHRoaXMuZGF0ZVRpbWUuZ2V0TW9udGgoKSArIDEpLnNsaWNlKC0yKSk7XG4gICAgdGhpcy5zZWxlY3RlZFllYXIgPSB0aGlzLmRhdGVUaW1lLmdldEZ1bGxZZWFyKCk7XG4gIH1cblxufVxuIiwiPGRpdiBjbGFzcz1cImNhbGVuZGFyX2RheXNcIj5cbiAgICBAZm9yIChkYXkgb2YgZGF5czsgbGV0IGluZHggPSAkaW5kZXg7IHRyYWNrIGluZHgpIHtcbiAgICAgICAgPGRpdlxuICAgICAgICAgICAgKGNsaWNrKT1cImRheSAmJiBjaG9vc2VEYXkoZGF5KVwiXG4gICAgICAgICAgICBbbmdDbGFzc109XCJ7XG4gICAgICAgICAgICAgICAgJ3NlbGVjdGVkX2RheSB0YS1mb250LWJvbGQnOlxuICAgICAgICAgICAgICAgICAgICBkYXkgPT09IHNlbGVjdGVkRGF5ICYmXG4gICAgICAgICAgICAgICAgICAgIHNlbGVjdGVkTW9udGhGcm9tSW5wdXQgPT09IHNlbE1vbnRoICYmXG4gICAgICAgICAgICAgICAgICAgIHNlbGVjdGVkWWVhckZyb21JbnB1dCA9PT0gc2VsZWN0ZWRZZWFyLFxuICAgICAgICAgICAgfVwiXG4gICAgICAgICAgICBbY2xhc3MuZW1wdHlfZGF5XT1cIiFkYXlcIlxuICAgICAgICAgICAgW2NsYXNzLmRheV9pbl9jdXJyZW50X21vbnRoXT1cImFjdGl2ZU1vbnRoXCJcbiAgICAgICAgICAgIFtjbGFzcy5jdXJyZW50X2RheV09XCJcbiAgICAgICAgICAgICAgICBkYXkgPT09IGN1cnJlbnREYXkgJiZcbiAgICAgICAgICAgICAgICB5ZWFyID09PSBjdXJyZW50WWVhciAmJlxuICAgICAgICAgICAgICAgIHNlbGVjdGVkTW9udGggPT09IGN1cnJlbnRNb250aC50b1N0cmluZygpXG4gICAgICAgICAgICBcIlxuICAgICAgICAgICAgY2xhc3M9XCJjYWxlbmRhcl9kYXkgdGEtZm9udC1tZWRpdW1cIlxuICAgICAgICA+XG4gICAgICAgICAgICA8c3Bhbj57eyBkYXkgfX08L3NwYW4+XG4gICAgICAgIDwvZGl2PlxuICAgIH1cbjwvZGl2PlxuIl19
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2EtY3VzdG9tLWRhdGV0aW1lLXBpY2tlcnMtY2FsZW5kYXItZGF5cy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jYS1jdXN0b20tZGF0ZXRpbWUtcGlja2Vycy9jb21wb25lbnRzL2NhLWN1c3RvbS1kYXRldGltZS1waWNrZXJzLWNhbGVuZGFyLWRheXMvY2EtY3VzdG9tLWRhdGV0aW1lLXBpY2tlcnMtY2FsZW5kYXItZGF5cy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jYS1jdXN0b20tZGF0ZXRpbWUtcGlja2Vycy9jb21wb25lbnRzL2NhLWN1c3RvbS1kYXRldGltZS1waWNrZXJzLWNhbGVuZGFyLWRheXMvY2EtY3VzdG9tLWRhdGV0aW1lLXBpY2tlcnMtY2FsZW5kYXItZGF5cy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMvRSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQVM3QyxNQUFNLE9BQU8sNENBQTRDO0lBaUJyRCxJQUNJLEtBQUssQ0FBQyxLQUFXO1FBQ2pCLElBQUksQ0FBQyxzQkFBc0IsR0FBRyxRQUFRLENBQ2xDLENBQUMsR0FBRyxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FDekMsQ0FBQztRQUNGLElBQUksQ0FBQyxxQkFBcUIsR0FBRyxLQUFLLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDakQsTUFBTSxXQUFXLEdBQUcsS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ25DLE1BQU0sT0FBTyxHQUFHLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLEVBQUUsRUFBRSxLQUFLLENBQUMsUUFBUSxFQUFFLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3ZFLE1BQU0sU0FBUyxHQUFHLE9BQU8sQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUVwQyxJQUFJLENBQUMsSUFBSSxHQUFHO1lBQ1IsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUUsTUFBTSxFQUFFLFdBQVcsRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLEVBQUUsQ0FBQztZQUNwRCxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1NBQzVELENBQUM7SUFDTixDQUFDO0lBRUQ7UUEzQlUsY0FBUyxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7UUFDbEMsZ0JBQVcsR0FBVyxJQUFJLElBQUksRUFBRSxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBQy9DLGlCQUFZLEdBQVcsSUFBSSxJQUFJLEVBQUUsQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUM3QyxlQUFVLEdBQVcsSUFBSSxJQUFJLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUcxQyxTQUFJLEdBQW1DLEVBQUUsQ0FBQztRQUMxQyxnQkFBVyxHQUFXLENBQUMsQ0FBQyxDQUFDO1FBQ3pCLGFBQVEsR0FBVyxDQUFDLENBQUMsQ0FBQztRQUN0QixpQkFBWSxHQUFXLENBQUMsQ0FBQyxDQUFDO0lBa0JsQixDQUFDO0lBRWhCLFFBQVE7UUFDSixJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVNLFNBQVMsQ0FBQyxHQUFvQjtRQUNqQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUM7SUFDcEQsQ0FBQztJQUVPLGVBQWU7UUFDbkIsSUFBSSxDQUFDLFdBQVcsR0FBRyxRQUFRLENBQUMsQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDdkUsSUFBSSxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQ3BCLENBQUMsR0FBRyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQ2pELENBQUM7UUFDRixJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDcEQsQ0FBQzsrR0FqRFEsNENBQTRDO21HQUE1Qyw0Q0FBNEMsd1JDWHpELHd6QkF1QkEseUREZGMsWUFBWSw0SEFBRSxXQUFXOzs0RkFFMUIsNENBQTRDO2tCQVB4RCxTQUFTOytCQUNJLDZDQUE2QyxjQUczQyxJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsV0FBVyxDQUFDO3dEQUczQixRQUFRO3NCQUFoQixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNJLFNBQVM7c0JBQWxCLE1BQU07Z0JBWUgsS0FBSztzQkFEUixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2FwcC1jYS1jdXN0b20tZGF0ZXRpbWUtcGlja2VyLWNhbGVuZGFyLWRheXMnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9jYS1jdXN0b20tZGF0ZXRpbWUtcGlja2Vycy1jYWxlbmRhci1kYXlzLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9jYS1jdXN0b20tZGF0ZXRpbWUtcGlja2Vycy1jYWxlbmRhci1kYXlzLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBGb3Jtc01vZHVsZV0sXG59KVxuZXhwb3J0IGNsYXNzIENhQ3VzdG9tRGF0ZVRpbWVQaWNrZXJzQ2FsZW5kYXJEYXlzQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBASW5wdXQoKSBkYXRlVGltZSE6IERhdGU7XG4gICAgQElucHV0KCkgeWVhciE6IG51bWJlcjtcbiAgICBASW5wdXQoKSBzZWxlY3RlZE1vbnRoITogc3RyaW5nO1xuICAgIEBJbnB1dCgpIGluZGV4ITogbnVtYmVyO1xuICAgIEBJbnB1dCgpIGFjdGl2ZU1vbnRoITogYm9vbGVhbjtcbiAgICBAT3V0cHV0KCkgc2VsZWN0RGF5ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuICAgIHB1YmxpYyBjdXJyZW50WWVhcjogbnVtYmVyID0gbmV3IERhdGUoKS5nZXRGdWxsWWVhcigpO1xuICAgIHB1YmxpYyBjdXJyZW50TW9udGg6IG51bWJlciA9IG5ldyBEYXRlKCkuZ2V0TW9udGgoKTtcbiAgICBwdWJsaWMgY3VycmVudERheTogbnVtYmVyID0gbmV3IERhdGUoKS5nZXREYXRlKCk7XG4gICAgcHVibGljIHNlbGVjdGVkTW9udGhGcm9tSW5wdXQhOiBudW1iZXI7XG4gICAgcHVibGljIHNlbGVjdGVkWWVhckZyb21JbnB1dCE6IG51bWJlcjtcbiAgICBwdWJsaWMgZGF5czogUmVhZG9ubHlBcnJheTxzdHJpbmcgfCBudW1iZXI+ID0gW107XG4gICAgcHVibGljIHNlbGVjdGVkRGF5OiBudW1iZXIgPSAtMTtcbiAgICBwdWJsaWMgc2VsTW9udGg6IG51bWJlciA9IC0xO1xuICAgIHB1YmxpYyBzZWxlY3RlZFllYXI6IG51bWJlciA9IC0xO1xuXG4gICAgQElucHV0KClcbiAgICBzZXQgbW9udGgobW9udGg6IERhdGUpIHtcbiAgICAgICAgdGhpcy5zZWxlY3RlZE1vbnRoRnJvbUlucHV0ID0gcGFyc2VJbnQoXG4gICAgICAgICAgICAoJzAnICsgbW9udGguZ2V0TW9udGgoKSArIDEpLnNsaWNlKC0yKVxuICAgICAgICApO1xuICAgICAgICB0aGlzLnNlbGVjdGVkWWVhckZyb21JbnB1dCA9IG1vbnRoLmdldEZ1bGxZZWFyKCk7XG4gICAgICAgIGNvbnN0IGZpbGxlckNvdW50ID0gbW9udGguZ2V0RGF5KCk7XG4gICAgICAgIGNvbnN0IGxhc3REYXkgPSBuZXcgRGF0ZShtb250aC5nZXRGdWxsWWVhcigpLCBtb250aC5nZXRNb250aCgpICsgMSwgMCk7XG4gICAgICAgIGNvbnN0IGRheXNDb3VudCA9IGxhc3REYXkuZ2V0RGF0ZSgpO1xuXG4gICAgICAgIHRoaXMuZGF5cyA9IFtcbiAgICAgICAgICAgIC4uLkFycmF5LmZyb20oeyBsZW5ndGg6IGZpbGxlckNvdW50IH0pLm1hcCgoKSA9PiAnJyksXG4gICAgICAgICAgICAuLi5BcnJheS5mcm9tKHsgbGVuZ3RoOiBkYXlzQ291bnQgfSkubWFwKChfLCBpKSA9PiBpICsgMSksXG4gICAgICAgIF07XG4gICAgfVxuXG4gICAgY29uc3RydWN0b3IoKSB7fVxuXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuc2V0U2VsZWN0ZWREYXRlKCk7XG4gICAgfVxuXG4gICAgcHVibGljIGNob29zZURheShkYXk6IG51bWJlciB8IHN0cmluZyk6IHZvaWQge1xuICAgICAgICB0aGlzLnNlbGVjdERheS5lbWl0KHsgaW5kZXg6IHRoaXMuaW5kZXgsIGRheSB9KTtcbiAgICB9XG5cbiAgICBwcml2YXRlIHNldFNlbGVjdGVkRGF0ZSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5zZWxlY3RlZERheSA9IHBhcnNlSW50KCgnMCcgKyB0aGlzLmRhdGVUaW1lLmdldERhdGUoKSkuc2xpY2UoLTIpKTtcbiAgICAgICAgdGhpcy5zZWxNb250aCA9IHBhcnNlSW50KFxuICAgICAgICAgICAgKCcwJyArIHRoaXMuZGF0ZVRpbWUuZ2V0TW9udGgoKSArIDEpLnNsaWNlKC0yKVxuICAgICAgICApO1xuICAgICAgICB0aGlzLnNlbGVjdGVkWWVhciA9IHRoaXMuZGF0ZVRpbWUuZ2V0RnVsbFllYXIoKTtcbiAgICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiY2FsZW5kYXJfZGF5c1wiPlxuICAgIEBmb3IgKGRheSBvZiBkYXlzOyBsZXQgaW5keCA9ICRpbmRleDsgdHJhY2sgaW5keCkge1xuICAgICAgICA8ZGl2XG4gICAgICAgICAgICAoY2xpY2spPVwiZGF5ICYmIGNob29zZURheShkYXkpXCJcbiAgICAgICAgICAgIFtuZ0NsYXNzXT1cIntcbiAgICAgICAgICAgICAgICAnc2VsZWN0ZWRfZGF5IHRhLWZvbnQtYm9sZCc6XG4gICAgICAgICAgICAgICAgICAgIGRheSA9PT0gc2VsZWN0ZWREYXkgJiZcbiAgICAgICAgICAgICAgICAgICAgc2VsZWN0ZWRNb250aEZyb21JbnB1dCA9PT0gc2VsTW9udGggJiZcbiAgICAgICAgICAgICAgICAgICAgc2VsZWN0ZWRZZWFyRnJvbUlucHV0ID09PSBzZWxlY3RlZFllYXIsXG4gICAgICAgICAgICB9XCJcbiAgICAgICAgICAgIFtjbGFzcy5lbXB0eV9kYXldPVwiIWRheVwiXG4gICAgICAgICAgICBbY2xhc3MuZGF5X2luX2N1cnJlbnRfbW9udGhdPVwiYWN0aXZlTW9udGhcIlxuICAgICAgICAgICAgW2NsYXNzLmN1cnJlbnRfZGF5XT1cIlxuICAgICAgICAgICAgICAgIGRheSA9PT0gY3VycmVudERheSAmJlxuICAgICAgICAgICAgICAgIHllYXIgPT09IGN1cnJlbnRZZWFyICYmXG4gICAgICAgICAgICAgICAgc2VsZWN0ZWRNb250aCA9PT0gY3VycmVudE1vbnRoLnRvU3RyaW5nKClcbiAgICAgICAgICAgIFwiXG4gICAgICAgICAgICBjbGFzcz1cImNhbGVuZGFyX2RheSB0YS1mb250LW1lZGl1bVwiXG4gICAgICAgID5cbiAgICAgICAgICAgIDxzcGFuPnt7IGRheSB9fTwvc3Bhbj5cbiAgICAgICAgPC9kaXY+XG4gICAgfVxuPC9kaXY+XG4iXX0=
@@ -1,4 +1,4 @@
1
- import { Component, forwardRef, Input, } from '@angular/core';
1
+ import { Component, forwardRef, Input } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import { FormsModule } from '@angular/forms';
4
4
  import { Subject, takeUntil } from 'rxjs';
@@ -62,7 +62,8 @@ export class CaCustomDateTimePickersCalendarLeftComponent {
62
62
  .pipe(takeUntil(this.destroy$))
63
63
  .subscribe((res) => {
64
64
  if (res.type != CalendarStringEnum.LEFT &&
65
- this.calendarService.selectedScroll != CalendarStringEnum.LEFT) {
65
+ this.calendarService.selectedScroll !=
66
+ CalendarStringEnum.LEFT) {
66
67
  const sizeTimes = CalendarLeftStringEnum.FULL_SIZE / res.cycleSize;
67
68
  const newScrollSize = sizeTimes * res.scrollOffset;
68
69
  this.scrollStrategy.scrollToOffset(newScrollSize, CalendarStringEnum.AUTO);
@@ -114,7 +115,9 @@ export class CaCustomDateTimePickersCalendarLeftComponent {
114
115
  {
115
116
  provide: VIRTUAL_SCROLL_STRATEGY,
116
117
  useFactory: factory,
117
- deps: [forwardRef(() => CaCustomDateTimePickersCalendarLeftComponent)],
118
+ deps: [
119
+ forwardRef(() => CaCustomDateTimePickersCalendarLeftComponent),
120
+ ],
118
121
  },
119
122
  ], ngImport: i0, template: "<div (mouseover)=\"mouseOverSetItem()\">\n <cdk-virtual-scroll-viewport\n #leftSideRef\n (scrolledIndexChange)=\"onScrollChanged($event)\"\n style=\"height: 290px; width: 100%; margin: 0\"\n >\n <ng-container\n *cdkVirtualFor=\"\n let month of months;\n let indx = index;\n templateCacheSize: 10\n \"\n >\n <div\n (click)=\"selectMonth(indx)\"\n class=\"month-year-item ta-font-medium\"\n [ngClass]=\"{\n 'current_month_year ta-font-bold': isMonthAndYearOnly\n ? indx === _currentYearIndex\n : indx === _activeIndex,\n }\"\n [innerHTML]=\"month | calendarmonths: listPreview\"\n ></div>\n </ng-container>\n </cdk-virtual-scroll-viewport>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: ScrollingModule }, { kind: "directive", type: i3.CdkVirtualForOf, selector: "[cdkVirtualFor][cdkVirtualForOf]", inputs: ["cdkVirtualForOf", "cdkVirtualForTrackBy", "cdkVirtualForTemplate", "cdkVirtualForTemplateCacheSize"] }, { kind: "component", type: i3.CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation", "appendOnly"], outputs: ["scrolledIndexChange"] }, { kind: "pipe", type: CalendarMonthsPipe, name: "calendarmonths" }] }); }
120
123
  }
@@ -124,7 +127,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
124
127
  {
125
128
  provide: VIRTUAL_SCROLL_STRATEGY,
126
129
  useFactory: factory,
127
- deps: [forwardRef(() => CaCustomDateTimePickersCalendarLeftComponent)],
130
+ deps: [
131
+ forwardRef(() => CaCustomDateTimePickersCalendarLeftComponent),
132
+ ],
128
133
  },
129
134
  ], template: "<div (mouseover)=\"mouseOverSetItem()\">\n <cdk-virtual-scroll-viewport\n #leftSideRef\n (scrolledIndexChange)=\"onScrollChanged($event)\"\n style=\"height: 290px; width: 100%; margin: 0\"\n >\n <ng-container\n *cdkVirtualFor=\"\n let month of months;\n let indx = index;\n templateCacheSize: 10\n \"\n >\n <div\n (click)=\"selectMonth(indx)\"\n class=\"month-year-item ta-font-medium\"\n [ngClass]=\"{\n 'current_month_year ta-font-bold': isMonthAndYearOnly\n ? indx === _currentYearIndex\n : indx === _activeIndex,\n }\"\n [innerHTML]=\"month | calendarmonths: listPreview\"\n ></div>\n </ng-container>\n </cdk-virtual-scroll-viewport>\n</div>\n" }]
130
135
  }], ctorParameters: () => [{ type: i1.CalendarDateTimePickerService }], propDecorators: { months: [{
@@ -140,4 +145,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
140
145
  }], activeIndex: [{
141
146
  type: Input
142
147
  }] } });
143
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-custom-datetime-pickers-calendar-left.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ca-components/src/lib/components/ca-custom-datetime-pickers/components/ca-custom-datetime-pickers-calendar-left/ca-custom-datetime-pickers-calendar-left.component.ts","../../../../../../../../projects/ca-components/src/lib/components/ca-custom-datetime-pickers/components/ca-custom-datetime-pickers-calendar-left/ca-custom-datetime-pickers-calendar-left.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  forwardRef,\n  Input,\n  OnInit,\n  OnDestroy,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\n\nimport { Subject, takeUntil } from 'rxjs';\n\n// services\nimport { CalendarDateTimePickerService } from '../../services/calendar-datetime-picker.service';\n\n// modules\nimport {\n  ScrollingModule,\n  VIRTUAL_SCROLL_STRATEGY,\n} from '@angular/cdk/scrolling';\n\n// pipes\nimport { CalendarMonthsPipe } from '../../pipes/calendar-months.pipe';\n\n// strategy\nimport {\n  CalendarStrategy,\n  STARTING_YEAR,\n} from '../../strategy/calendar-strategy';\n\n// enums\nimport { CalendarLeftStringEnum } from '../../enums/calendar-left-string.enum';\nimport { CalendarListPreviewStringEnum } from '../../enums/calendar-list-preview-string.enum';\nimport { CalendarStringEnum } from '../../enums/calendar-string.enum';\n\nfunction factory(dir: CaCustomDateTimePickersCalendarLeftComponent) {\n  return dir.scrollStrategy;\n}\n\n@Component({\n  selector: 'app-ca-custom-datetime-pickers-calendar-left',\n  templateUrl: './ca-custom-datetime-pickers-calendar-left.component.html',\n  styleUrls: ['./ca-custom-datetime-pickers-calendar-left.component.scss'],\n  standalone: true,\n  imports: [CommonModule, FormsModule, ScrollingModule, CalendarMonthsPipe],\n  providers: [\n    {\n      provide: VIRTUAL_SCROLL_STRATEGY,\n      useFactory: factory,\n      deps: [forwardRef(() => CaCustomDateTimePickersCalendarLeftComponent)],\n    },\n  ],\n})\nexport class CaCustomDateTimePickersCalendarLeftComponent\n  implements OnInit, OnDestroy {\n  @Input() months!: Date[];\n  @Input() currentIndex!: number;\n  @Input() isMonthAndYearOnly: boolean = false;\n\n  public _listPreview!: string;\n  @Input() set listPreview(value: string) {\n    this._listPreview = value;\n    this.scrollStrategy.updateScrollHeights(\n      value === CalendarListPreviewStringEnum.MONTH_LIST\n        ? CalendarLeftStringEnum.CYCLE_HEIGHT_BY_MONTHS\n        : CalendarLeftStringEnum.CYCLE_HEIGHT\n    );\n  }\n\n  public _currentYearIndex: number = 0;\n  @Input() set currentYearIndex(value: number) {\n    this._currentYearIndex = value;\n    if (this.isMonthAndYearOnly && this._currentYearIndex)\n      setTimeout(() => {\n        this.scrollStrategy.scrollToIndex(\n          this._currentYearIndex,\n          CalendarStringEnum.AUTO\n        );\n      }, 200);\n  }\n\n  public _activeIndex: number = 0;\n  @Input() set activeIndex(value: number) {\n    this._activeIndex = value;\n    if (!this.isMonthAndYearOnly && this._activeIndex)\n      setTimeout(() => {\n        this.scrollStrategy.scrollToIndex(\n          this._activeIndex,\n          CalendarStringEnum.AUTO\n        );\n      }, 200);\n  }\n  public isHovered!: boolean;\n  private isFirstCall: boolean = true;\n\n  private destroy$ = new Subject<void>();\n\n  constructor(private calendarService: CalendarDateTimePickerService) { }\n\n  scrollStrategy: CalendarStrategy = new CalendarStrategy(\n    this.calendarService,\n    CalendarLeftStringEnum.CYCLE_HEIGHT,\n    CalendarLeftStringEnum.FULL_SIZE,\n    CalendarStringEnum.LEFT\n  );\n\n  ngOnInit(): void {\n    this.initScrollListeners();\n  }\n\n  public initScrollListeners(): void {\n    this.calendarService.scrollToAutoIndex\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((indx) => {\n        this.scrollStrategy.scrollToIndex(indx, CalendarStringEnum.AUTO);\n      });\n\n    this.calendarService.scrolledIndexChange\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((res) => {\n        if (\n          res.type != CalendarStringEnum.LEFT &&\n          this.calendarService.selectedScroll != CalendarStringEnum.LEFT\n        ) {\n          const sizeTimes = CalendarLeftStringEnum.FULL_SIZE / res.cycleSize;\n          const newScrollSize = sizeTimes * res.scrollOffset;\n          this.scrollStrategy.scrollToOffset(\n            newScrollSize,\n            CalendarStringEnum.AUTO\n          );\n        }\n      });\n\n    this.calendarService.scrollToDate\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((res) => {\n        setTimeout(() => {\n          if (res) {\n            const indx = this.findIndexInMonth(res);\n            this.scrollStrategy.scrollToIndex(indx, CalendarStringEnum.AUTO);\n          } else\n            this.scrollStrategy.scrollToIndex(\n              this.currentIndex,\n              CalendarStringEnum.AUTO\n            );\n        });\n      });\n\n    if (this.isMonthAndYearOnly) {\n      setTimeout(() => {\n        if (this.isFirstCall) {\n          this.scrollStrategy.updateScrollHeights(\n            CalendarLeftStringEnum.CYCLE_HEIGHT_BY_MONTHS\n          );\n\n          this.scrollStrategy.scrollToIndex(\n            this._currentYearIndex,\n            CalendarStringEnum.AUTO\n          );\n\n          this.isFirstCall = false;\n        }\n      }, 200);\n    }\n  }\n\n  public findIndexInMonth(date: string): number {\n    const selectedDate = new Date(date);\n    const indexMonth = (selectedDate.getFullYear() - STARTING_YEAR) * 12;\n    const indx = indexMonth + selectedDate.getMonth();\n    return indx;\n  }\n\n  public onScrollChanged(data: any): void {\n    this.calendarService.index$.next(data);\n  }\n\n  public selectMonth(indx: number): void {\n    this.scrollStrategy.scrollToIndex(indx, CalendarStringEnum.AUTO);\n  }\n\n  public mouseOverSetItem(): void {\n    this.calendarService.scrolledScrollItem = CalendarStringEnum.LEFT;\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n","<div (mouseover)=\"mouseOverSetItem()\">\n    <cdk-virtual-scroll-viewport\n        #leftSideRef\n        (scrolledIndexChange)=\"onScrollChanged($event)\"\n        style=\"height: 290px; width: 100%; margin: 0\"\n    >\n        <ng-container\n            *cdkVirtualFor=\"\n                let month of months;\n                let indx = index;\n                templateCacheSize: 10\n            \"\n        >\n            <div\n                (click)=\"selectMonth(indx)\"\n                class=\"month-year-item ta-font-medium\"\n                [ngClass]=\"{\n                    'current_month_year ta-font-bold': isMonthAndYearOnly\n                        ? indx === _currentYearIndex\n                        : indx === _activeIndex,\n                }\"\n                [innerHTML]=\"month | calendarmonths: listPreview\"\n            ></div>\n        </ng-container>\n    </cdk-virtual-scroll-viewport>\n</div>\n"]}
148
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-custom-datetime-pickers-calendar-left.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ca-components/src/lib/components/ca-custom-datetime-pickers/components/ca-custom-datetime-pickers-calendar-left/ca-custom-datetime-pickers-calendar-left.component.ts","../../../../../../../../projects/ca-components/src/lib/components/ca-custom-datetime-pickers/components/ca-custom-datetime-pickers-calendar-left/ca-custom-datetime-pickers-calendar-left.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input, OnInit, OnDestroy } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\n\nimport { Subject, takeUntil } from 'rxjs';\n\n// services\nimport { CalendarDateTimePickerService } from '../../services/calendar-datetime-picker.service';\n\n// modules\nimport {\n    ScrollingModule,\n    VIRTUAL_SCROLL_STRATEGY,\n} from '@angular/cdk/scrolling';\n\n// pipes\nimport { CalendarMonthsPipe } from '../../pipes/calendar-months.pipe';\n\n// strategy\nimport {\n    CalendarStrategy,\n    STARTING_YEAR,\n} from '../../strategy/calendar-strategy';\n\n// enums\nimport { CalendarLeftStringEnum } from '../../enums/calendar-left-string.enum';\nimport { CalendarListPreviewStringEnum } from '../../enums/calendar-list-preview-string.enum';\nimport { CalendarStringEnum } from '../../enums/calendar-string.enum';\n\nfunction factory(dir: CaCustomDateTimePickersCalendarLeftComponent) {\n    return dir.scrollStrategy;\n}\n\n@Component({\n    selector: 'app-ca-custom-datetime-pickers-calendar-left',\n    templateUrl: './ca-custom-datetime-pickers-calendar-left.component.html',\n    styleUrls: ['./ca-custom-datetime-pickers-calendar-left.component.scss'],\n    standalone: true,\n    imports: [CommonModule, FormsModule, ScrollingModule, CalendarMonthsPipe],\n    providers: [\n        {\n            provide: VIRTUAL_SCROLL_STRATEGY,\n            useFactory: factory,\n            deps: [\n                forwardRef(() => CaCustomDateTimePickersCalendarLeftComponent),\n            ],\n        },\n    ],\n})\nexport class CaCustomDateTimePickersCalendarLeftComponent\n    implements OnInit, OnDestroy\n{\n    @Input() months!: Date[];\n    @Input() currentIndex!: number;\n    @Input() isMonthAndYearOnly: boolean = false;\n\n    public _listPreview!: string;\n    @Input() set listPreview(value: string) {\n        this._listPreview = value;\n        this.scrollStrategy.updateScrollHeights(\n            value === CalendarListPreviewStringEnum.MONTH_LIST\n                ? CalendarLeftStringEnum.CYCLE_HEIGHT_BY_MONTHS\n                : CalendarLeftStringEnum.CYCLE_HEIGHT\n        );\n    }\n\n    public _currentYearIndex: number = 0;\n    @Input() set currentYearIndex(value: number) {\n        this._currentYearIndex = value;\n        if (this.isMonthAndYearOnly && this._currentYearIndex)\n            setTimeout(() => {\n                this.scrollStrategy.scrollToIndex(\n                    this._currentYearIndex,\n                    CalendarStringEnum.AUTO\n                );\n            }, 200);\n    }\n\n    public _activeIndex: number = 0;\n    @Input() set activeIndex(value: number) {\n        this._activeIndex = value;\n        if (!this.isMonthAndYearOnly && this._activeIndex)\n            setTimeout(() => {\n                this.scrollStrategy.scrollToIndex(\n                    this._activeIndex,\n                    CalendarStringEnum.AUTO\n                );\n            }, 200);\n    }\n    public isHovered!: boolean;\n    private isFirstCall: boolean = true;\n\n    private destroy$ = new Subject<void>();\n\n    constructor(private calendarService: CalendarDateTimePickerService) {}\n\n    scrollStrategy: CalendarStrategy = new CalendarStrategy(\n        this.calendarService,\n        CalendarLeftStringEnum.CYCLE_HEIGHT,\n        CalendarLeftStringEnum.FULL_SIZE,\n        CalendarStringEnum.LEFT\n    );\n\n    ngOnInit(): void {\n        this.initScrollListeners();\n    }\n\n    public initScrollListeners(): void {\n        this.calendarService.scrollToAutoIndex\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((indx) => {\n                this.scrollStrategy.scrollToIndex(\n                    indx,\n                    CalendarStringEnum.AUTO\n                );\n            });\n\n        this.calendarService.scrolledIndexChange\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((res) => {\n                if (\n                    res.type != CalendarStringEnum.LEFT &&\n                    this.calendarService.selectedScroll !=\n                        CalendarStringEnum.LEFT\n                ) {\n                    const sizeTimes =\n                        CalendarLeftStringEnum.FULL_SIZE / res.cycleSize;\n                    const newScrollSize = sizeTimes * res.scrollOffset;\n                    this.scrollStrategy.scrollToOffset(\n                        newScrollSize,\n                        CalendarStringEnum.AUTO\n                    );\n                }\n            });\n\n        this.calendarService.scrollToDate\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((res) => {\n                setTimeout(() => {\n                    if (res) {\n                        const indx = this.findIndexInMonth(res);\n                        this.scrollStrategy.scrollToIndex(\n                            indx,\n                            CalendarStringEnum.AUTO\n                        );\n                    } else\n                        this.scrollStrategy.scrollToIndex(\n                            this.currentIndex,\n                            CalendarStringEnum.AUTO\n                        );\n                });\n            });\n\n        if (this.isMonthAndYearOnly) {\n            setTimeout(() => {\n                if (this.isFirstCall) {\n                    this.scrollStrategy.updateScrollHeights(\n                        CalendarLeftStringEnum.CYCLE_HEIGHT_BY_MONTHS\n                    );\n\n                    this.scrollStrategy.scrollToIndex(\n                        this._currentYearIndex,\n                        CalendarStringEnum.AUTO\n                    );\n\n                    this.isFirstCall = false;\n                }\n            }, 200);\n        }\n    }\n\n    public findIndexInMonth(date: string): number {\n        const selectedDate = new Date(date);\n        const indexMonth = (selectedDate.getFullYear() - STARTING_YEAR) * 12;\n        const indx = indexMonth + selectedDate.getMonth();\n        return indx;\n    }\n\n    public onScrollChanged(data: any): void {\n        this.calendarService.index$.next(data);\n    }\n\n    public selectMonth(indx: number): void {\n        this.scrollStrategy.scrollToIndex(indx, CalendarStringEnum.AUTO);\n    }\n\n    public mouseOverSetItem(): void {\n        this.calendarService.scrolledScrollItem = CalendarStringEnum.LEFT;\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}","<div (mouseover)=\"mouseOverSetItem()\">\n    <cdk-virtual-scroll-viewport\n        #leftSideRef\n        (scrolledIndexChange)=\"onScrollChanged($event)\"\n        style=\"height: 290px; width: 100%; margin: 0\"\n    >\n        <ng-container\n            *cdkVirtualFor=\"\n                let month of months;\n                let indx = index;\n                templateCacheSize: 10\n            \"\n        >\n            <div\n                (click)=\"selectMonth(indx)\"\n                class=\"month-year-item ta-font-medium\"\n                [ngClass]=\"{\n                    'current_month_year ta-font-bold': isMonthAndYearOnly\n                        ? indx === _currentYearIndex\n                        : indx === _activeIndex,\n                }\"\n                [innerHTML]=\"month | calendarmonths: listPreview\"\n            ></div>\n        </ng-container>\n    </cdk-virtual-scroll-viewport>\n</div>\n"]}