barsa-calendar 1.0.340 → 1.0.342

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.
@@ -81,7 +81,7 @@ export class CalendarSelectionDaysComponent extends BaseComponent {
81
81
  const { endDay, startDay } = this.getStartAndEndDay(monthInfo, day);
82
82
  this.startSelectedDayIndex = startDay?.index;
83
83
  this.endSelectedDayIndex = endDay?.index;
84
- console.log('-move-', this.startSelectedDay?.index, this.endSelectedDay?.index);
84
+ // console.log('-move-', this.startSelectedDay?.index, this.endSelectedDay?.index);
85
85
  }
86
86
  }
87
87
  onDayMouseDown(day) {
@@ -132,7 +132,7 @@ export class CalendarSelectionDaysComponent extends BaseComponent {
132
132
  endDay = this.endSelectedDay;
133
133
  }
134
134
  }
135
- console.log('-2-', startDay, endDay);
135
+ // console.log('-2-', startDay, endDay);
136
136
  if (startDay && endDay) {
137
137
  const diff = Math.abs(startDay.momentOfDate.diff(endDay.momentOfDate, 'day'));
138
138
  if (diff > 6) {
@@ -143,13 +143,13 @@ export class CalendarSelectionDaysComponent extends BaseComponent {
143
143
  // indexEnd++;
144
144
  // }
145
145
  endDay = monthInfo.days[indexEnd * 7 - 1];
146
- console.log('-3-', startDay, endDay);
146
+ // console.log('-3-', startDay, endDay);
147
147
  }
148
148
  }
149
149
  return { endDay, startDay };
150
150
  }
151
151
  _setFirstAndEndDay(monthInfo, popover) {
152
- console.log('-finish-', this.startSelectedDay, this.endSelectedDay);
152
+ // console.log('-finish-', this.startSelectedDay, this.endSelectedDay);
153
153
  if (this.startSelectedDay && this.endSelectedDay) {
154
154
  if (popover) {
155
155
  popover.close();
@@ -190,4 +190,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
190
190
  }], rangeChange: [{
191
191
  type: Output
192
192
  }] } });
193
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-selection-days.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-calendar/src/lib/calendar-selection-days/calendar-selection-days.component.ts","../../../../../projects/barsa-calendar/src/lib/calendar-selection-days/calendar-selection-days.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    EventEmitter,\r\n    Input,\r\n    OnChanges,\r\n    Output,\r\n    Self,\r\n    SimpleChanges\r\n} from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { distinctUntilChanged, map } from 'rxjs/operators';\r\nimport { BaseComponent, DateService, getDateService, PortalService } from 'barsa-novin-ray-core';\r\nimport { CalendarMonthInfo, Day } from '../models';\r\nimport { CalendarService } from '../services/calendar.service';\r\n@Component({\r\n    selector: 'bc-calendar-selection-days',\r\n    templateUrl: './calendar-selection-days.component.html',\r\n    styleUrls: ['./calendar-selection-days.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [\r\n        {\r\n            provide: DateService,\r\n            useFactory: getDateService\r\n        },\r\n        CalendarService\r\n    ]\r\n})\r\nexport class CalendarSelectionDaysComponent extends BaseComponent implements OnChanges {\r\n    @Input() startSelectedDayIndex: number | undefined;\r\n    @Input() endSelectedDayIndex: number | undefined;\r\n    @Input() monthInfo: CalendarMonthInfo;\r\n    @Output() rangeChange = new EventEmitter<{\r\n        startDay: Day;\r\n        endDay: Day;\r\n        monthInfo: CalendarMonthInfo;\r\n    }>();\r\n    selectionMode: 'day' | 'month' | 'year' = 'day';\r\n\r\n    endSelectedDay: Day | null;\r\n    startSelectedDay: Day | null;\r\n    width$: Observable<number>;\r\n    height: number;\r\n    selectedMonth$: Observable<CalendarMonthInfo>;\r\n    rtl$: Observable<boolean>;\r\n    today: Date;\r\n    weekDaysMin: string[];\r\n    weekDays: string[];\r\n    deviceSize$: Observable<string>;\r\n    months: string[] = [];\r\n    years: string[];\r\n    private _isMouseDown = false;\r\n    constructor(@Self() private _calendarService: CalendarService, _portalService: PortalService) {\r\n        super();\r\n        this.rtl$ = _portalService.rtl$;\r\n        this.width$ = _portalService.deviceSize$.pipe(\r\n            distinctUntilChanged(),\r\n            map((deviceSize) => {\r\n                switch (deviceSize) {\r\n                    case 'l':\r\n                    case 'xl':\r\n                        return 480;\r\n                    case 's':\r\n                        return 320;\r\n                    default:\r\n                        return 480;\r\n                }\r\n            })\r\n        );\r\n        this.weekDaysMin = this._calendarService.weekDaysMin();\r\n        this.weekDays = this._calendarService.weekDays();\r\n        this.selectedMonth$ = this._calendarService.selected$;\r\n        this.today = this._calendarService.today;\r\n        this.months = this._calendarService.Months;\r\n        this._prepareYear(this._calendarService.selectedMonth.dateInfo.year);\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        super.ngOnChanges(changes);\r\n        const { monthInfo } = changes;\r\n        if (monthInfo) {\r\n            this._calendarService.loadCalendarMonthInfo(monthInfo.currentValue);\r\n        }\r\n    }\r\n    onMonthSelected(monthName: string, index: number): void {\r\n        this._calendarService.gotoMonth(monthName, index);\r\n    }\r\n    onYearSelected(year: string): void {\r\n        this._calendarService.gotoYear(+year);\r\n    }\r\n\r\n    onPrevTap(): void {\r\n        if (this.selectionMode === 'day') {\r\n            this._calendarService.loadPrevious();\r\n        } else if (this.selectionMode === 'month') {\r\n            this._calendarService.loadPrevYear();\r\n        } else if (this.selectionMode === 'year') {\r\n            this._prepareYear(Number(this.years[0]) - 20);\r\n        }\r\n    }\r\n\r\n    onNextTap(): void {\r\n        if (this.selectionMode === 'day') {\r\n            this._calendarService.loadNext();\r\n        } else if (this.selectionMode === 'month') {\r\n            this._calendarService.loadNextYear();\r\n        } else if (this.selectionMode === 'year') {\r\n            this._prepareYear(Number(this.years[this.years.length - 1]) + 1);\r\n        }\r\n    }\r\n\r\n    onToday(): void {\r\n        this._calendarService.gotoToday();\r\n    }\r\n    onDayMouseMove(day: Day, monthInfo: CalendarMonthInfo): void {\r\n        if (this._isMouseDown) {\r\n            const { endDay, startDay } = this.getStartAndEndDay(monthInfo, day);\r\n            this.startSelectedDayIndex = startDay?.index;\r\n            this.endSelectedDayIndex = endDay?.index;\r\n            console.log('-move-', this.startSelectedDay?.index, this.endSelectedDay?.index);\r\n        }\r\n    }\r\n\r\n    onDayMouseDown(day: Day): void {\r\n        this._isMouseDown = true;\r\n        this.startSelectedDay = null;\r\n        this.endSelectedDay = null;\r\n        this.startSelectedDay = day;\r\n        this.startSelectedDayIndex = day.index;\r\n    }\r\n    onDayMouseUp(day: Day, monthInfo, popover): void {\r\n        this._isMouseDown = false;\r\n\r\n        const { endDay, startDay } = this.getStartAndEndDay(monthInfo, day);\r\n        this.startSelectedDay = startDay;\r\n        this.endSelectedDay = endDay;\r\n        this._setFirstAndEndDay(monthInfo, popover);\r\n    }\r\n    onDayClick(day: Day, monthInfo, popover): void {\r\n        this.startSelectedDay = this.endSelectedDay = day;\r\n        this._setFirstAndEndDay(monthInfo, popover);\r\n    }\r\n    private _prepareYear(from: number): void {\r\n        const years: string[] = [];\r\n        for (let i = 0; i < 20; i++) {\r\n            years.push(`${from + i}`);\r\n        }\r\n        this.years = years;\r\n    }\r\n    private getStartAndEndDay(\r\n        monthInfo: CalendarMonthInfo,\r\n        day: Day | null\r\n    ): { endDay: Day | null; startDay: Day | null } {\r\n        let startDay: Day | null = null;\r\n        let endDay: Day | null = null;\r\n        if (this.startSelectedDay && !this.endSelectedDay) {\r\n            if (day && this.startSelectedDay.date > day.date) {\r\n                startDay = day;\r\n                endDay = this.startSelectedDay;\r\n            } else {\r\n                startDay = this.startSelectedDay;\r\n                endDay = day;\r\n            }\r\n        } else if (this.startSelectedDay && this.endSelectedDay) {\r\n            if (day && this.startSelectedDay.date < day.date) {\r\n                startDay = this.startSelectedDay;\r\n                endDay = day;\r\n            } else {\r\n                startDay = day;\r\n                endDay = this.endSelectedDay;\r\n            }\r\n        }\r\n        console.log('-2-', startDay, endDay);\r\n        if (startDay && endDay) {\r\n            const diff = Math.abs(startDay.momentOfDate.diff(endDay.momentOfDate, 'day'));\r\n            if (diff > 6) {\r\n                startDay = monthInfo.days[Math.floor(startDay.index / 7) * 7];\r\n                // const end = endDay.index % 7;\r\n                const indexEnd = Math.ceil((endDay.index + 1) / 7);\r\n                // if (end > 0) {\r\n                //     indexEnd++;\r\n                // }\r\n                endDay = monthInfo.days[indexEnd * 7 - 1];\r\n                console.log('-3-', startDay, endDay);\r\n            }\r\n        }\r\n        return { endDay, startDay };\r\n    }\r\n\r\n    private _setFirstAndEndDay(monthInfo, popover): void {\r\n        console.log('-finish-', this.startSelectedDay, this.endSelectedDay);\r\n        if (this.startSelectedDay && this.endSelectedDay) {\r\n            if (popover) {\r\n                popover.close();\r\n            }\r\n            this.rangeChange.emit({\r\n                startDay: this.startSelectedDay,\r\n                endDay: this.endSelectedDay,\r\n                monthInfo\r\n            });\r\n        }\r\n    }\r\n}\r\n","<fdp-button glyph=\"calendar\" buttonType=\"transparent\" [fdPopoverTrigger]=\"popover\"></fdp-button>\n<fd-popover #popover [focusTrapped]=\"true\" [focusAutoCapture]=\"true\" [mobile]=\"(deviceSize$ | async) === 's'\">\n    <fd-popover-body [style.width.px]=\"width$ | async\">\n        <ng-container\n            *ngTemplateOutlet=\"\n                month;\n                context: {\n                    $implicit: selectedMonth$ | async,\n                    width: width$ | async,\n                    height: height,\n                    rtl: rtl$ | async,\n                    weekDays: weekDays,\n                    weekDaysMin: weekDaysMin,\n                    today: today,\n                    deviceSize: deviceSize$ | async,\n                    popover: popover\n                }\n            \"\n        >\n        </ng-container>\n    </fd-popover-body>\n</fd-popover>\n\n<ng-template\n    #month\n    let-selectedMonth\n    let-width=\"width\"\n    let-height=\"height\"\n    let-rtl=\"rtl\"\n    let-today=\"today\"\n    let-showEvents=\"showEvents\"\n    let-deviceSize=\"deviceSize\"\n    let-popover=\"popover\"\n>\n    <fd-toolbar [fdType]=\"'transparent'\">\n        <fdp-button fd-toolbar-item [label]=\"'DateR_Today' | bbbTranslate\" (click)=\"onToday()\"></fdp-button>\n        <fdp-button\n            buttonType=\"transparent\"\n            fd-toolbar-item\n            [glyph]=\"rtl ? 'navigation-right-arrow' : 'navigation-left-arrow'\"\n            (click)=\"onPrevTap()\"\n        ></fdp-button>\n        <fdp-button\n            buttonType=\"transparent\"\n            fd-toolbar-item\n            [glyph]=\"rtl ? 'navigation-left-arrow' : 'navigation-right-arrow'\"\n            (click)=\"onNextTap()\"\n        ></fdp-button>\n        <div class=\"month-years-wrapper\" fd-title fd-toolbar-item>\n            <button\n                *ngIf=\"selectionMode === 'day' || selectionMode === 'month'\"\n                fd-button\n                [fdType]=\"'transparent'\"\n                [label]=\"selectedMonth.dateInfo.monthName\"\n                (click)=\"selectionMode = 'month'\"\n            ></button>\n            <button\n                fd-button\n                [fdType]=\"'transparent'\"\n                [label]=\"selectedMonth.dateInfo.year\"\n                (click)=\"selectionMode = 'year'\"\n            ></button>\n        </div>\n    </fd-toolbar>\n    <ng-container [ngSwitch]=\"selectionMode\">\n        <ng-container *ngSwitchCase=\"'month'\">\n            <div class=\"month-year-selection-wrapper\">\n                <button\n                    style=\"flex-grow: 1; width: 33%\"\n                    *ngFor=\"let month of months; let i = index\"\n                    fd-button\n                    [fdType]=\"selectedMonth.dateInfo.monthName === month ? 'emphasized' : 'transparent'\"\n                    [label]=\"month\"\n                    (click)=\"selectionMode = 'day'; onMonthSelected(month, i)\"\n                ></button>\n            </div>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'year'\">\n            <div class=\"month-year-selection-wrapper\">\n                <button\n                    style=\"flex-grow: 1; width: 25%\"\n                    *ngFor=\"let year of years\"\n                    fd-button\n                    [fdType]=\"selectedMonth.dateInfo.year === +year ? 'emphasized' : 'transparent'\"\n                    [label]=\"year\"\n                    (click)=\"selectionMode = 'day'; onYearSelected(year)\"\n                ></button>\n            </div>\n        </ng-container>\n        <bc-calendar-month\n            *ngSwitchDefault\n            [style.width]=\"width\"\n            [containerHeight]=\"height\"\n            [containerWidth]=\"width\"\n            [rtl]=\"rtl\"\n            [monthWeeksCount]=\"6\"\n            [weekDays]=\"weekDays\"\n            [weekDaysMin]=\"weekDaysMin\"\n            [today]=\"today\"\n            [datePicker]=\"true\"\n            [dateRange]=\"true\"\n            [days]=\"selectedMonth.days\"\n            [deviceSize]=\"deviceSize\"\n            (dayClick)=\"onDayClick($event, selectedMonth, popover)\"\n            (dayMouseMove)=\"onDayMouseMove($event, selectedMonth)\"\n            (dayMouseUp)=\"onDayMouseUp($event, selectedMonth, popover)\"\n            (dayMouseDown)=\"onDayMouseDown($event)\"\n            [startSelectedDayIndex]=\"startSelectedDayIndex\"\n            [endSelectedDayIndex]=\"endSelectedDayIndex\"\n        ></bc-calendar-month>\n    </ng-container>\n</ng-template>\n"]}
193
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-selection-days.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-calendar/src/lib/calendar-selection-days/calendar-selection-days.component.ts","../../../../../projects/barsa-calendar/src/lib/calendar-selection-days/calendar-selection-days.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    Output,\n    Self,\n    SimpleChanges\n} from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { distinctUntilChanged, map } from 'rxjs/operators';\nimport { BaseComponent, DateService, getDateService, PortalService } from 'barsa-novin-ray-core';\nimport { CalendarMonthInfo, Day } from '../models';\nimport { CalendarService } from '../services/calendar.service';\n@Component({\n    selector: 'bc-calendar-selection-days',\n    templateUrl: './calendar-selection-days.component.html',\n    styleUrls: ['./calendar-selection-days.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: DateService,\n            useFactory: getDateService\n        },\n        CalendarService\n    ]\n})\nexport class CalendarSelectionDaysComponent extends BaseComponent implements OnChanges {\n    @Input() startSelectedDayIndex: number | undefined;\n    @Input() endSelectedDayIndex: number | undefined;\n    @Input() monthInfo: CalendarMonthInfo;\n    @Output() rangeChange = new EventEmitter<{\n        startDay: Day;\n        endDay: Day;\n        monthInfo: CalendarMonthInfo;\n    }>();\n    selectionMode: 'day' | 'month' | 'year' = 'day';\n\n    endSelectedDay: Day | null;\n    startSelectedDay: Day | null;\n    width$: Observable<number>;\n    height: number;\n    selectedMonth$: Observable<CalendarMonthInfo>;\n    rtl$: Observable<boolean>;\n    today: Date;\n    weekDaysMin: string[];\n    weekDays: string[];\n    deviceSize$: Observable<string>;\n    months: string[] = [];\n    years: string[];\n    private _isMouseDown = false;\n    constructor(@Self() private _calendarService: CalendarService, _portalService: PortalService) {\n        super();\n        this.rtl$ = _portalService.rtl$;\n        this.width$ = _portalService.deviceSize$.pipe(\n            distinctUntilChanged(),\n            map((deviceSize) => {\n                switch (deviceSize) {\n                    case 'l':\n                    case 'xl':\n                        return 480;\n                    case 's':\n                        return 320;\n                    default:\n                        return 480;\n                }\n            })\n        );\n        this.weekDaysMin = this._calendarService.weekDaysMin();\n        this.weekDays = this._calendarService.weekDays();\n        this.selectedMonth$ = this._calendarService.selected$;\n        this.today = this._calendarService.today;\n        this.months = this._calendarService.Months;\n        this._prepareYear(this._calendarService.selectedMonth.dateInfo.year);\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        super.ngOnChanges(changes);\n        const { monthInfo } = changes;\n        if (monthInfo) {\n            this._calendarService.loadCalendarMonthInfo(monthInfo.currentValue);\n        }\n    }\n    onMonthSelected(monthName: string, index: number): void {\n        this._calendarService.gotoMonth(monthName, index);\n    }\n    onYearSelected(year: string): void {\n        this._calendarService.gotoYear(+year);\n    }\n\n    onPrevTap(): void {\n        if (this.selectionMode === 'day') {\n            this._calendarService.loadPrevious();\n        } else if (this.selectionMode === 'month') {\n            this._calendarService.loadPrevYear();\n        } else if (this.selectionMode === 'year') {\n            this._prepareYear(Number(this.years[0]) - 20);\n        }\n    }\n\n    onNextTap(): void {\n        if (this.selectionMode === 'day') {\n            this._calendarService.loadNext();\n        } else if (this.selectionMode === 'month') {\n            this._calendarService.loadNextYear();\n        } else if (this.selectionMode === 'year') {\n            this._prepareYear(Number(this.years[this.years.length - 1]) + 1);\n        }\n    }\n\n    onToday(): void {\n        this._calendarService.gotoToday();\n    }\n    onDayMouseMove(day: Day, monthInfo: CalendarMonthInfo): void {\n        if (this._isMouseDown) {\n            const { endDay, startDay } = this.getStartAndEndDay(monthInfo, day);\n            this.startSelectedDayIndex = startDay?.index;\n            this.endSelectedDayIndex = endDay?.index;\n            // console.log('-move-', this.startSelectedDay?.index, this.endSelectedDay?.index);\n        }\n    }\n\n    onDayMouseDown(day: Day): void {\n        this._isMouseDown = true;\n        this.startSelectedDay = null;\n        this.endSelectedDay = null;\n        this.startSelectedDay = day;\n        this.startSelectedDayIndex = day.index;\n    }\n    onDayMouseUp(day: Day, monthInfo, popover): void {\n        this._isMouseDown = false;\n\n        const { endDay, startDay } = this.getStartAndEndDay(monthInfo, day);\n        this.startSelectedDay = startDay;\n        this.endSelectedDay = endDay;\n        this._setFirstAndEndDay(monthInfo, popover);\n    }\n    onDayClick(day: Day, monthInfo, popover): void {\n        this.startSelectedDay = this.endSelectedDay = day;\n        this._setFirstAndEndDay(monthInfo, popover);\n    }\n    private _prepareYear(from: number): void {\n        const years: string[] = [];\n        for (let i = 0; i < 20; i++) {\n            years.push(`${from + i}`);\n        }\n        this.years = years;\n    }\n    private getStartAndEndDay(\n        monthInfo: CalendarMonthInfo,\n        day: Day | null\n    ): { endDay: Day | null; startDay: Day | null } {\n        let startDay: Day | null = null;\n        let endDay: Day | null = null;\n        if (this.startSelectedDay && !this.endSelectedDay) {\n            if (day && this.startSelectedDay.date > day.date) {\n                startDay = day;\n                endDay = this.startSelectedDay;\n            } else {\n                startDay = this.startSelectedDay;\n                endDay = day;\n            }\n        } else if (this.startSelectedDay && this.endSelectedDay) {\n            if (day && this.startSelectedDay.date < day.date) {\n                startDay = this.startSelectedDay;\n                endDay = day;\n            } else {\n                startDay = day;\n                endDay = this.endSelectedDay;\n            }\n        }\n        // console.log('-2-', startDay, endDay);\n        if (startDay && endDay) {\n            const diff = Math.abs(startDay.momentOfDate.diff(endDay.momentOfDate, 'day'));\n            if (diff > 6) {\n                startDay = monthInfo.days[Math.floor(startDay.index / 7) * 7];\n                // const end = endDay.index % 7;\n                const indexEnd = Math.ceil((endDay.index + 1) / 7);\n                // if (end > 0) {\n                //     indexEnd++;\n                // }\n                endDay = monthInfo.days[indexEnd * 7 - 1];\n                // console.log('-3-', startDay, endDay);\n            }\n        }\n        return { endDay, startDay };\n    }\n\n    private _setFirstAndEndDay(monthInfo, popover): void {\n        // console.log('-finish-', this.startSelectedDay, this.endSelectedDay);\n        if (this.startSelectedDay && this.endSelectedDay) {\n            if (popover) {\n                popover.close();\n            }\n            this.rangeChange.emit({\n                startDay: this.startSelectedDay,\n                endDay: this.endSelectedDay,\n                monthInfo\n            });\n        }\n    }\n}\n","<fdp-button glyph=\"calendar\" buttonType=\"transparent\" [fdPopoverTrigger]=\"popover\"></fdp-button>\n<fd-popover #popover [focusTrapped]=\"true\" [focusAutoCapture]=\"true\" [mobile]=\"(deviceSize$ | async) === 's'\">\n    <fd-popover-body [style.width.px]=\"width$ | async\">\n        <ng-container\n            *ngTemplateOutlet=\"\n                month;\n                context: {\n                    $implicit: selectedMonth$ | async,\n                    width: width$ | async,\n                    height: height,\n                    rtl: rtl$ | async,\n                    weekDays: weekDays,\n                    weekDaysMin: weekDaysMin,\n                    today: today,\n                    deviceSize: deviceSize$ | async,\n                    popover: popover\n                }\n            \"\n        >\n        </ng-container>\n    </fd-popover-body>\n</fd-popover>\n\n<ng-template\n    #month\n    let-selectedMonth\n    let-width=\"width\"\n    let-height=\"height\"\n    let-rtl=\"rtl\"\n    let-today=\"today\"\n    let-showEvents=\"showEvents\"\n    let-deviceSize=\"deviceSize\"\n    let-popover=\"popover\"\n>\n    <fd-toolbar [fdType]=\"'transparent'\">\n        <fdp-button fd-toolbar-item [label]=\"'DateR_Today' | bbbTranslate\" (click)=\"onToday()\"></fdp-button>\n        <fdp-button\n            buttonType=\"transparent\"\n            fd-toolbar-item\n            [glyph]=\"rtl ? 'navigation-right-arrow' : 'navigation-left-arrow'\"\n            (click)=\"onPrevTap()\"\n        ></fdp-button>\n        <fdp-button\n            buttonType=\"transparent\"\n            fd-toolbar-item\n            [glyph]=\"rtl ? 'navigation-left-arrow' : 'navigation-right-arrow'\"\n            (click)=\"onNextTap()\"\n        ></fdp-button>\n        <div class=\"month-years-wrapper\" fd-title fd-toolbar-item>\n            <button\n                *ngIf=\"selectionMode === 'day' || selectionMode === 'month'\"\n                fd-button\n                [fdType]=\"'transparent'\"\n                [label]=\"selectedMonth.dateInfo.monthName\"\n                (click)=\"selectionMode = 'month'\"\n            ></button>\n            <button\n                fd-button\n                [fdType]=\"'transparent'\"\n                [label]=\"selectedMonth.dateInfo.year\"\n                (click)=\"selectionMode = 'year'\"\n            ></button>\n        </div>\n    </fd-toolbar>\n    <ng-container [ngSwitch]=\"selectionMode\">\n        <ng-container *ngSwitchCase=\"'month'\">\n            <div class=\"month-year-selection-wrapper\">\n                <button\n                    style=\"flex-grow: 1; width: 33%\"\n                    *ngFor=\"let month of months; let i = index\"\n                    fd-button\n                    [fdType]=\"selectedMonth.dateInfo.monthName === month ? 'emphasized' : 'transparent'\"\n                    [label]=\"month\"\n                    (click)=\"selectionMode = 'day'; onMonthSelected(month, i)\"\n                ></button>\n            </div>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'year'\">\n            <div class=\"month-year-selection-wrapper\">\n                <button\n                    style=\"flex-grow: 1; width: 25%\"\n                    *ngFor=\"let year of years\"\n                    fd-button\n                    [fdType]=\"selectedMonth.dateInfo.year === +year ? 'emphasized' : 'transparent'\"\n                    [label]=\"year\"\n                    (click)=\"selectionMode = 'day'; onYearSelected(year)\"\n                ></button>\n            </div>\n        </ng-container>\n        <bc-calendar-month\n            *ngSwitchDefault\n            [style.width]=\"width\"\n            [containerHeight]=\"height\"\n            [containerWidth]=\"width\"\n            [rtl]=\"rtl\"\n            [monthWeeksCount]=\"6\"\n            [weekDays]=\"weekDays\"\n            [weekDaysMin]=\"weekDaysMin\"\n            [today]=\"today\"\n            [datePicker]=\"true\"\n            [dateRange]=\"true\"\n            [days]=\"selectedMonth.days\"\n            [deviceSize]=\"deviceSize\"\n            (dayClick)=\"onDayClick($event, selectedMonth, popover)\"\n            (dayMouseMove)=\"onDayMouseMove($event, selectedMonth)\"\n            (dayMouseUp)=\"onDayMouseUp($event, selectedMonth, popover)\"\n            (dayMouseDown)=\"onDayMouseDown($event)\"\n            [startSelectedDayIndex]=\"startSelectedDayIndex\"\n            [endSelectedDayIndex]=\"endSelectedDayIndex\"\n        ></bc-calendar-month>\n    </ng-container>\n</ng-template>\n"]}
@@ -1306,12 +1306,11 @@ class CalendarSelectionDaysComponent extends BaseComponent {
1306
1306
  this._calendarService.gotoToday();
1307
1307
  }
1308
1308
  onDayMouseMove(day, monthInfo) {
1309
- var _a, _b;
1310
1309
  if (this._isMouseDown) {
1311
1310
  const { endDay, startDay } = this.getStartAndEndDay(monthInfo, day);
1312
1311
  this.startSelectedDayIndex = startDay === null || startDay === void 0 ? void 0 : startDay.index;
1313
1312
  this.endSelectedDayIndex = endDay === null || endDay === void 0 ? void 0 : endDay.index;
1314
- console.log('-move-', (_a = this.startSelectedDay) === null || _a === void 0 ? void 0 : _a.index, (_b = this.endSelectedDay) === null || _b === void 0 ? void 0 : _b.index);
1313
+ // console.log('-move-', this.startSelectedDay?.index, this.endSelectedDay?.index);
1315
1314
  }
1316
1315
  }
1317
1316
  onDayMouseDown(day) {
@@ -1362,7 +1361,7 @@ class CalendarSelectionDaysComponent extends BaseComponent {
1362
1361
  endDay = this.endSelectedDay;
1363
1362
  }
1364
1363
  }
1365
- console.log('-2-', startDay, endDay);
1364
+ // console.log('-2-', startDay, endDay);
1366
1365
  if (startDay && endDay) {
1367
1366
  const diff = Math.abs(startDay.momentOfDate.diff(endDay.momentOfDate, 'day'));
1368
1367
  if (diff > 6) {
@@ -1373,13 +1372,13 @@ class CalendarSelectionDaysComponent extends BaseComponent {
1373
1372
  // indexEnd++;
1374
1373
  // }
1375
1374
  endDay = monthInfo.days[indexEnd * 7 - 1];
1376
- console.log('-3-', startDay, endDay);
1375
+ // console.log('-3-', startDay, endDay);
1377
1376
  }
1378
1377
  }
1379
1378
  return { endDay, startDay };
1380
1379
  }
1381
1380
  _setFirstAndEndDay(monthInfo, popover) {
1382
- console.log('-finish-', this.startSelectedDay, this.endSelectedDay);
1381
+ // console.log('-finish-', this.startSelectedDay, this.endSelectedDay);
1383
1382
  if (this.startSelectedDay && this.endSelectedDay) {
1384
1383
  if (popover) {
1385
1384
  popover.close();