New file |
0,0 → 1,108 |
/* |
Copyright (c) 2004-2006, The Dojo Foundation |
All Rights Reserved. |
|
Licensed under the Academic Free License version 2.1 or above OR the |
modified BSD license. For more information on Dojo licensing, see: |
|
http://dojotoolkit.org/community/licensing.shtml |
*/ |
|
dojo.provide("dojo.widget.DropdownDatePicker"); |
dojo.require("dojo.widget.*"); |
dojo.require("dojo.widget.DropdownContainer"); |
dojo.require("dojo.widget.DatePicker"); |
dojo.require("dojo.event.*"); |
dojo.require("dojo.html.*"); |
dojo.require("dojo.date.format"); |
dojo.require("dojo.date.serialize"); |
dojo.require("dojo.string.common"); |
dojo.require("dojo.i18n.common"); |
dojo.requireLocalization("dojo.widget", "DropdownDatePicker", null, "ROOT"); |
dojo.widget.defineWidget("dojo.widget.DropdownDatePicker", dojo.widget.DropdownContainer, {iconURL:dojo.uri.moduleUri("dojo.widget", "templates/images/dateIcon.gif"), formatLength:"short", displayFormat:"", saveFormat:"", value:"", name:"", displayWeeks:6, adjustWeeks:false, startDate:"1492-10-12", endDate:"2941-10-12", weekStartsOn:"", staticDisplay:false, postMixInProperties:function (localProperties, frag) { |
dojo.widget.DropdownDatePicker.superclass.postMixInProperties.apply(this, arguments); |
var messages = dojo.i18n.getLocalization("dojo.widget", "DropdownDatePicker", this.lang); |
this.iconAlt = messages.selectDate; |
if (typeof (this.value) == "string" && this.value.toLowerCase() == "today") { |
this.value = new Date(); |
} |
if (this.value && isNaN(this.value)) { |
var orig = this.value; |
this.value = dojo.date.fromRfc3339(this.value); |
if (!this.value) { |
this.value = new Date(orig); |
dojo.deprecated("dojo.widget.DropdownDatePicker", "date attributes must be passed in Rfc3339 format", "0.5"); |
} |
} |
if (this.value && !isNaN(this.value)) { |
this.value = new Date(this.value); |
} |
}, fillInTemplate:function (args, frag) { |
dojo.widget.DropdownDatePicker.superclass.fillInTemplate.call(this, args, frag); |
var dpArgs = {widgetContainerId:this.widgetId, lang:this.lang, value:this.value, startDate:this.startDate, endDate:this.endDate, displayWeeks:this.displayWeeks, weekStartsOn:this.weekStartsOn, adjustWeeks:this.adjustWeeks, staticDisplay:this.staticDisplay}; |
this.datePicker = dojo.widget.createWidget("DatePicker", dpArgs, this.containerNode, "child"); |
dojo.event.connect(this.datePicker, "onValueChanged", this, "_updateText"); |
dojo.event.connect(this.inputNode, "onChange", this, "_updateText"); |
if (this.value) { |
this._updateText(); |
} |
this.containerNode.explodeClassName = "calendarBodyContainer"; |
this.valueNode.name = this.name; |
}, getValue:function () { |
return this.valueNode.value; |
}, getDate:function () { |
return this.datePicker.value; |
}, setValue:function (rfcDate) { |
this.setDate(rfcDate); |
}, setDate:function (dateObj) { |
this.datePicker.setDate(dateObj); |
this._syncValueNode(); |
}, _updateText:function () { |
this.inputNode.value = this.datePicker.value ? dojo.date.format(this.datePicker.value, {formatLength:this.formatLength, datePattern:this.displayFormat, selector:"dateOnly", locale:this.lang}) : ""; |
if (this.value < this.datePicker.startDate || this.value > this.datePicker.endDate) { |
this.inputNode.value = ""; |
} |
this._syncValueNode(); |
this.onValueChanged(this.getDate()); |
this.hideContainer(); |
}, onValueChanged:function (dateObj) { |
}, onInputChange:function () { |
var input = dojo.string.trim(this.inputNode.value); |
if (input) { |
var inputDate = dojo.date.parse(input, {formatLength:this.formatLength, datePattern:this.displayFormat, selector:"dateOnly", locale:this.lang}); |
if (!this.datePicker._isDisabledDate(inputDate)) { |
this.setDate(inputDate); |
} |
} else { |
if (input == "") { |
this.datePicker.setDate(""); |
} |
this.valueNode.value = input; |
} |
if (input) { |
this._updateText(); |
} |
}, _syncValueNode:function () { |
var date = this.datePicker.value; |
var value = ""; |
switch (this.saveFormat.toLowerCase()) { |
case "rfc": |
case "iso": |
case "": |
value = dojo.date.toRfc3339(date, "dateOnly"); |
break; |
case "posix": |
case "unix": |
value = Number(date); |
break; |
default: |
if (date) { |
value = dojo.date.format(date, {datePattern:this.saveFormat, selector:"dateOnly", locale:this.lang}); |
} |
} |
this.valueNode.value = value; |
}, destroy:function (finalize) { |
this.datePicker.destroy(finalize); |
dojo.widget.DropdownDatePicker.superclass.destroy.apply(this, arguments); |
}}); |
|