diff options
author | Keith Wood <kbwood.au@gmail.com> | 2009-04-10 08:04:57 +0000 |
---|---|---|
committer | Keith Wood <kbwood.au@gmail.com> | 2009-04-10 08:04:57 +0000 |
commit | f754cf11119fae0ee34c8b4aaa5d321b170901d4 (patch) | |
tree | 013d2a57617d9e9506a9953fa7e21a7bf2c12797 /ui/ui.datepicker.js | |
parent | 1f2dcf8af9740ae5f65e4f4623bd6f0fafd3ba58 (diff) | |
download | jquery-ui-f754cf11119fae0ee34c8b4aaa5d321b170901d4.tar.gz jquery-ui-f754cf11119fae0ee34c8b4aaa5d321b170901d4.zip |
Datepicker: Apply min/max settings on setDate
Diffstat (limited to 'ui/ui.datepicker.js')
-rw-r--r-- | ui/ui.datepicker.js | 27 |
1 files changed, 14 insertions, 13 deletions
diff --git a/ui/ui.datepicker.js b/ui/ui.datepicker.js index 3a13c9425..e41bcb414 100644 --- a/ui/ui.datepicker.js +++ b/ui/ui.datepicker.js @@ -1148,12 +1148,8 @@ $.extend(Datepicker.prototype, { /* Retrieve the default date shown on opening. */ _getDefaultDate: function(inst) { - var date = this._determineDate(this._get(inst, 'defaultDate'), new Date()); - var minDate = this._getMinMaxDate(inst, 'min', true); - var maxDate = this._getMinMaxDate(inst, 'max'); - date = (minDate && date < minDate ? minDate : date); - date = (maxDate && date > maxDate ? maxDate : date); - return date; + return this._restrictMinMax(inst, + this._determineDate(this._get(inst, 'defaultDate'), new Date())); }, /* A date may be specified as an exact value or a relative one. */ @@ -1219,7 +1215,7 @@ $.extend(Datepicker.prototype, { var clear = !(date); var origMonth = inst.selectedMonth; var origYear = inst.selectedYear; - date = this._determineDate(date, new Date()); + date = this._restrictMinMax(inst, this._determineDate(date, new Date())); inst.selectedDay = inst.currentDay = date.getDate(); inst.drawMonth = inst.selectedMonth = inst.currentMonth = date.getMonth(); inst.drawYear = inst.selectedYear = inst.currentYear = date.getFullYear(); @@ -1470,12 +1466,8 @@ $.extend(Datepicker.prototype, { var month = inst.drawMonth + (period == 'M' ? offset : 0); var day = Math.min(inst.selectedDay, this._getDaysInMonth(year, month)) + (period == 'D' ? offset : 0); - var date = this._daylightSavingAdjust(new Date(year, month, day)); - // ensure it is within the bounds set - var minDate = this._getMinMaxDate(inst, 'min', true); - var maxDate = this._getMinMaxDate(inst, 'max'); - date = (minDate && date < minDate ? minDate : date); - date = (maxDate && date > maxDate ? maxDate : date); + var date = this._restrictMinMax(inst, + this._daylightSavingAdjust(new Date(year, month, day))); inst.selectedDay = date.getDate(); inst.drawMonth = inst.selectedMonth = date.getMonth(); inst.drawYear = inst.selectedYear = date.getFullYear(); @@ -1483,6 +1475,15 @@ $.extend(Datepicker.prototype, { this._notifyChange(inst); }, + /* Ensure a date is within any min/max bounds. */ + _restrictMinMax: function(inst, date) { + var minDate = this._getMinMaxDate(inst, 'min'); + var maxDate = this._getMinMaxDate(inst, 'max'); + date = (minDate && date < minDate ? minDate : date); + date = (maxDate && date > maxDate ? maxDate : date); + return date; + }, + /* Notify change of month/year. */ _notifyChange: function(inst) { var onChange = this._get(inst, 'onChangeMonthYear'); |