From e7f709f0a7f135188bf9746783790663290126fd Mon Sep 17 00:00:00 2001 From: Dave Anderson Date: Fri, 27 Nov 2015 23:30:02 -0500 Subject: [PATCH] fix(datepicker): fix minDate/maxDate with literals - Fixes use of min-date and max-date with literal strings Closes #4841 Fixes #3437 --- src/datepicker/datepicker.js | 6 +++--- src/datepicker/test/datepicker.spec.js | 25 +++++++++++++++++++++++++ 2 files changed, 28 insertions(+), 3 deletions(-) diff --git a/src/datepicker/datepicker.js b/src/datepicker/datepicker.js index 973261a7fb..2435e26793 100644 --- a/src/datepicker/datepicker.js +++ b/src/datepicker/datepicker.js @@ -42,7 +42,7 @@ angular.module('ui.bootstrap.datepicker', ['ui.bootstrap.dateparser', 'ui.bootst angular.forEach(['minDate', 'maxDate'], function(key) { if ($attrs[key]) { $scope.$parent.$watch($attrs[key], function(value) { - self[key] = value ? new Date(value) : null; + self[key] = value ? angular.isDate(value) ? new Date(value) : new Date(dateFilter(value, 'medium')) : null; self.refreshView(); }); } else { @@ -631,10 +631,10 @@ function(scope, element, attrs, $compile, $parse, $document, $rootScope, $positi if (attrs[key]) { var getAttribute = $parse(attrs[key]); scope.$parent.$watch(getAttribute, function(value) { - scope.watchData[key] = value; if (key === 'minDate' || key === 'maxDate') { - cache[key] = new Date(value); + cache[key] = angular.isDate(value) ? new Date(value) : new Date(dateFilter(value, 'medium')); } + scope.watchData[key] = cache[key] || value; }); datepickerEl.attr(cameltoDash(key), 'watchData.' + key); diff --git a/src/datepicker/test/datepicker.spec.js b/src/datepicker/test/datepicker.spec.js index 31fc97ab1c..e5702d34aa 100644 --- a/src/datepicker/test/datepicker.spec.js +++ b/src/datepicker/test/datepicker.spec.js @@ -965,6 +965,20 @@ describe('datepicker', function() { }); + describe('`min-date` attribute', function () { + beforeEach(function() { + element = $compile('')($rootScope); + $rootScope.$digest(); + }); + + it('accepts literals, \'yyyy-MM-dd\' case', function() { + var buttons = getAllOptionsEl(); + angular.forEach(buttons, function(button, index) { + expect(angular.element(button).prop('disabled')).toBe(index < 7); + }); + }); + }); + describe('`max-date` attribute', function() { beforeEach(function() { $rootScope.maxdate = new Date('September 25, 2010'); @@ -2011,6 +2025,17 @@ describe('datepicker', function() { expect(buttons.eq(0).prop('disabled')).toBe(true); }); + it('should disable today button if before min date, yyyy-MM-dd case', inject(function(dateFilter) { + var minDate = new Date(new Date().setDate(new Date().getDate() + 1)); + var literalMinDate = dateFilter(minDate, 'yyyy-MM-dd'); + var wrapElement = $compile('
')($rootScope); + $rootScope.$digest(); + assignElements(wrapElement); + assignButtonBar(); + + expect(buttons.eq(0).prop('disabled')).toBe(true); + })); + it('should disable today button if after max date', function() { $rootScope.maxDate = new Date().setDate(new Date().getDate() - 2); var wrapElement = $compile('
')($rootScope);