DropdownDatePicker.js
上传用户:kimgenplus
上传日期:2016-06-05
资源大小:20877k
文件大小:4k
源码类别:

OA系统

开发平台:

Java

  1. /*
  2. Copyright (c) 2004-2006, The Dojo Foundation
  3. All Rights Reserved.
  4. Licensed under the Academic Free License version 2.1 or above OR the
  5. modified BSD license. For more information on Dojo licensing, see:
  6. http://dojotoolkit.org/community/licensing.shtml
  7. */
  8. dojo.provide("dojo.widget.DropdownDatePicker");
  9. dojo.require("dojo.widget.*");
  10. dojo.require("dojo.widget.DropdownContainer");
  11. dojo.require("dojo.widget.DatePicker");
  12. dojo.require("dojo.event.*");
  13. dojo.require("dojo.html.*");
  14. dojo.require("dojo.date.format");
  15. dojo.require("dojo.date.serialize");
  16. dojo.require("dojo.string.common");
  17. dojo.require("dojo.i18n.common");
  18. dojo.requireLocalization("dojo.widget", "DropdownDatePicker", null, "ROOT");
  19. 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) {
  20. dojo.widget.DropdownDatePicker.superclass.postMixInProperties.apply(this, arguments);
  21. var messages = dojo.i18n.getLocalization("dojo.widget", "DropdownDatePicker", this.lang);
  22. this.iconAlt = messages.selectDate;
  23. if (typeof (this.value) == "string" && this.value.toLowerCase() == "today") {
  24. this.value = new Date();
  25. }
  26. if (this.value && isNaN(this.value)) {
  27. var orig = this.value;
  28. this.value = dojo.date.fromRfc3339(this.value);
  29. if (!this.value) {
  30. this.value = new Date(orig);
  31. dojo.deprecated("dojo.widget.DropdownDatePicker", "date attributes must be passed in Rfc3339 format", "0.5");
  32. }
  33. }
  34. if (this.value && !isNaN(this.value)) {
  35. this.value = new Date(this.value);
  36. }
  37. }, fillInTemplate:function (args, frag) {
  38. dojo.widget.DropdownDatePicker.superclass.fillInTemplate.call(this, args, frag);
  39. 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};
  40. this.datePicker = dojo.widget.createWidget("DatePicker", dpArgs, this.containerNode, "child");
  41. dojo.event.connect(this.datePicker, "onValueChanged", this, "_updateText");
  42. dojo.event.connect(this.inputNode, "onChange", this, "_updateText");
  43. if (this.value) {
  44. this._updateText();
  45. }
  46. this.containerNode.explodeClassName = "calendarBodyContainer";
  47. this.valueNode.name = this.name;
  48. }, getValue:function () {
  49. return this.valueNode.value;
  50. }, getDate:function () {
  51. return this.datePicker.value;
  52. }, setValue:function (rfcDate) {
  53. this.setDate(rfcDate);
  54. }, setDate:function (dateObj) {
  55. this.datePicker.setDate(dateObj);
  56. this._syncValueNode();
  57. }, _updateText:function () {
  58. this.inputNode.value = this.datePicker.value ? dojo.date.format(this.datePicker.value, {formatLength:this.formatLength, datePattern:this.displayFormat, selector:"dateOnly", locale:this.lang}) : "";
  59. if (this.value < this.datePicker.startDate || this.value > this.datePicker.endDate) {
  60. this.inputNode.value = "";
  61. }
  62. this._syncValueNode();
  63. this.onValueChanged(this.getDate());
  64. this.hideContainer();
  65. }, onValueChanged:function (dateObj) {
  66. }, onInputChange:function () {
  67. var input = dojo.string.trim(this.inputNode.value);
  68. if (input) {
  69. var inputDate = dojo.date.parse(input, {formatLength:this.formatLength, datePattern:this.displayFormat, selector:"dateOnly", locale:this.lang});
  70. if (!this.datePicker._isDisabledDate(inputDate)) {
  71. this.setDate(inputDate);
  72. }
  73. } else {
  74. if (input == "") {
  75. this.datePicker.setDate("");
  76. }
  77. this.valueNode.value = input;
  78. }
  79. if (input) {
  80. this._updateText();
  81. }
  82. }, _syncValueNode:function () {
  83. var date = this.datePicker.value;
  84. var value = "";
  85. switch (this.saveFormat.toLowerCase()) {
  86.   case "rfc":
  87.   case "iso":
  88.   case "":
  89. value = dojo.date.toRfc3339(date, "dateOnly");
  90. break;
  91.   case "posix":
  92.   case "unix":
  93. value = Number(date);
  94. break;
  95.   default:
  96. if (date) {
  97. value = dojo.date.format(date, {datePattern:this.saveFormat, selector:"dateOnly", locale:this.lang});
  98. }
  99. }
  100. this.valueNode.value = value;
  101. }, destroy:function (finalize) {
  102. this.datePicker.destroy(finalize);
  103. dojo.widget.DropdownDatePicker.superclass.destroy.apply(this, arguments);
  104. }});