From 2be72970405bb3da86b4f61eeb5de92546792ee2 Mon Sep 17 00:00:00 2001 From: mdlufy Date: Tue, 8 Oct 2024 18:45:38 +0300 Subject: [PATCH] fix(kit): `CalendarRange` show actual `defaultViewedMonth` --- .../primitive-calendar-range.component.ts | 25 +++++++++++++++---- ...primitive-calendar-range.component.spec.ts | 16 ++++++++++++ 2 files changed, 36 insertions(+), 5 deletions(-) diff --git a/projects/kit/internal/primitive-calendar-range/primitive-calendar-range.component.ts b/projects/kit/internal/primitive-calendar-range/primitive-calendar-range.component.ts index e05159e0a046..cfdef280a57c 100644 --- a/projects/kit/internal/primitive-calendar-range/primitive-calendar-range.component.ts +++ b/projects/kit/internal/primitive-calendar-range/primitive-calendar-range.component.ts @@ -5,10 +5,12 @@ import { EventEmitter, Inject, Input, + OnChanges, OnInit, Optional, Output, Self, + SimpleChanges, } from '@angular/core'; import { ALWAYS_FALSE_HANDLER, @@ -37,7 +39,7 @@ import {takeUntil} from 'rxjs/operators'; changeDetection: ChangeDetectionStrategy.OnPush, providers: [TuiDestroyService], }) -export class TuiPrimitiveCalendarRangeComponent implements OnInit { +export class TuiPrimitiveCalendarRangeComponent implements OnInit, OnChanges { @Input() disabledItemHandler: TuiBooleanHandler = ALWAYS_FALSE_HANDLER; @@ -99,6 +101,19 @@ export class TuiPrimitiveCalendarRangeComponent implements OnInit { monthOffset: TuiTypedMapper<[TuiMonth, number], TuiMonth> = (value, offset) => value.append({month: offset}); + ngOnChanges({ + defaultViewedMonthFirst, + defaultViewedMonthSecond, + }: SimpleChanges): void { + this.userViewedMonthSecond = this.updatedViewedMonthSecond( + defaultViewedMonthFirst?.currentValue ?? this.userViewedMonthSecond, + ); + + this.userViewedMonthFirst = this.updatedViewedMonthFirst( + defaultViewedMonthSecond?.currentValue ?? this.userViewedMonthFirst, + ); + } + ngOnInit(): void { this.setInitialMonths(); } @@ -158,9 +173,9 @@ export class TuiPrimitiveCalendarRangeComponent implements OnInit { } private updateViewedMonths(): void { - this.userViewedMonthFirst = - this.value === null ? this.defaultViewedMonthFirst : this.value.from; - - this.userViewedMonthSecond = this.userViewedMonthFirst.append({month: 1}); + if (this.value) { + this.userViewedMonthFirst = this.value.from; + this.userViewedMonthSecond = this.userViewedMonthFirst.append({month: 1}); + } } } diff --git a/projects/kit/internal/primitive-calendar-range/test/primitive-calendar-range.component.spec.ts b/projects/kit/internal/primitive-calendar-range/test/primitive-calendar-range.component.spec.ts index d8c8c3e9f32e..89171c221365 100644 --- a/projects/kit/internal/primitive-calendar-range/test/primitive-calendar-range.component.spec.ts +++ b/projects/kit/internal/primitive-calendar-range/test/primitive-calendar-range.component.spec.ts @@ -141,4 +141,20 @@ describe('PrimitiveRangeCalendar component', () => { expect(component.cappedUserViewedMonthSecond).toBe(day); }); }); + + it('When handle any changes, current viewed month do not updates', () => { + const date = TuiMonth.currentLocal().append({month: 3}); + + component.userViewedMonthFirst = date; + component.userViewedMonthSecond = date.append({month: 1}); + + component.markerHandler = (day: TuiDay) => + day.day % 2 === 0 ? ['first'] : ['second']; + component.ngOnChanges({}); + + expect(component.userViewedMonthFirst.toString()).toBe(date.toString()); + expect(component.userViewedMonthSecond.toString()).toBe( + date.append({month: 1}).toString(), + ); + }); });