From dddaf7fae4a1b70c60a8b305747e0454a09bf59e Mon Sep 17 00:00:00 2001 From: arcdev Date: Sun, 24 Sep 2017 20:31:38 -0400 Subject: [PATCH] fix(datepicker): initDate does not change Closes 6636 --- src/datepicker/datepicker.js | 8 ++++++-- src/datepicker/test/datepicker.spec.js | 24 ++++++++++++++++++++++-- 2 files changed, 28 insertions(+), 4 deletions(-) diff --git a/src/datepicker/datepicker.js b/src/datepicker/datepicker.js index fd4e263660..25f8c16ff2 100644 --- a/src/datepicker/datepicker.js +++ b/src/datepicker/datepicker.js @@ -164,10 +164,14 @@ angular.module('ui.bootstrap.datepicker', ['ui.bootstrap.dateparser', 'ui.bootst ngModelOptions = extractOptions(ngModelCtrl); if ($scope.datepickerOptions.initDate) { - self.activeDate = dateParser.fromTimezone($scope.datepickerOptions.initDate, ngModelOptions.getOption('timezone')) || new Date(); +// self.activeDate = dateParser.fromTimezone($scope.datepickerOptions.initDate, ngModelOptions.getOption('timezone')) || new Date(); + var newInitDate = dateParser.fromTimezone($scope.datepickerOptions.initDate, ngModelOptions.getOption('timezone')) || new Date(); + self.activeDate = angular.isDate(newInitDate) ? new Date(newInitDate.getTime()) : newInitDate; $scope.$watch('datepickerOptions.initDate', function(initDate) { if (initDate && (ngModelCtrl.$isEmpty(ngModelCtrl.$modelValue) || ngModelCtrl.$invalid)) { - self.activeDate = dateParser.fromTimezone(initDate, ngModelOptions.getOption('timezone')); +// self.activeDate = dateParser.fromTimezone(initDate, ngModelOptions.getOption('timezone')); + var updatedInitDate = dateParser.fromTimezone(initDate, ngModelOptions.getOption('timezone')); + self.activeDate = angular.isDate(updatedInitDate) ? new Date(updatedInitDate.getTime()) : updatedInitDate; self.refreshView(); } }); diff --git a/src/datepicker/test/datepicker.spec.js b/src/datepicker/test/datepicker.spec.js index 8dd924c8d8..b76ed38796 100644 --- a/src/datepicker/test/datepicker.spec.js +++ b/src/datepicker/test/datepicker.spec.js @@ -1535,10 +1535,13 @@ describe('datepicker', function() { }); describe('`init-date`', function() { + var expectedYear = 1980; + var expectedMonth = 10; + var expectedDay = 22; beforeEach(inject(function() { $rootScope.date = null; $rootScope.options = { - initDate: new Date('November 9, 1980') + initDate: new Date(expectedYear, expectedMonth, expectedDay) }; element = $compile('
')($rootScope); $rootScope.$digest(); @@ -1550,7 +1553,24 @@ describe('datepicker', function() { it('shows the correct title', function() { expect(getTitle()).toBe('November 1980'); - }); + }); + + it('does not change on click Next', function(){ + clickNextButton(); + var initDate = $rootScope.options.initDate; + var actual = initDate.getFullYear() + '-' + (initDate.getMonth()+1) + '-' + initDate.getDate(); + var expected = expectedYear + '-' + (expectedMonth+1) + '-' + expectedDay; + + expect(actual).toBe(expected); + }); + it('does not change on click Previous', function(){ + clickPreviousButton(); + var initDate = $rootScope.options.initDate; + var actual = initDate.getFullYear() + '-' + (initDate.getMonth()+1) + '-' + initDate.getDate(); + var expected = expectedYear + '-' + (expectedMonth+1) + '-' + expectedDay; + + expect(actual).toBe(expected); + }); }); describe('`datepicker-mode`', function() {