calendar.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249
  1. /*
  2. [Discuz!] (C)2001-2099 Comsenz Inc.
  3. This is NOT a freeware, use is subject to license terms
  4. $Id: calendar.js 33082 2013-04-18 11:13:53Z zhengqingpeng $
  5. */
  6. var controlid = null;
  7. var currdate = null;
  8. var startdate = null;
  9. var enddate = null;
  10. var halfhour = false;
  11. var yy = null;
  12. var mm = null;
  13. var hh = null;
  14. var ii = null;
  15. var currday = null;
  16. var addtime = false;
  17. var today = new Date();
  18. var lastcheckedyear = false;
  19. var lastcheckedmonth = false;
  20. var calendarrecall = null;
  21. function loadcalendar() {
  22. s = '';
  23. s += '<div id="calendar" style="display:none; position:absolute; z-index:100000;" onclick="doane(event)">';
  24. s += '<div style="width: 210px;"><table cellspacing="0" cellpadding="0" width="100%" style="text-align: center;">';
  25. s += '<tr align="center" id="calendar_week"><td onclick="refreshcalendar(yy, mm-1)" title="上一月" style="cursor: pointer;"><a href="javascript:;">&laquo;</a></td><td colspan="5" style="text-align: center"><a href="javascript:;" onclick="showdiv(\'year\');doane(event)" class="dropmenu" title="点击选择年份" id="year"></a>&nbsp; - &nbsp;<a id="month" class="dropmenu" title="点击选择月份" href="javascript:;" onclick="showdiv(\'month\');doane(event)"></a></td><td onclick="refreshcalendar(yy, mm+1)" title="下一月" style="cursor: pointer;"><a href="javascript:;">&raquo;</a></td></tr>';
  26. s += '<tr id="calendar_header"><td>日</td><td>一</td><td>二</td><td>三</td><td>四</td><td>五</td><td>六</td></tr>';
  27. for(var i = 0; i < 6; i++) {
  28. s += '<tr>';
  29. for(var j = 1; j <= 7; j++)
  30. s += "<td id=d" + (i * 7 + j) + " height=\"19\">0</td>";
  31. s += "</tr>";
  32. }
  33. s += '<tr id="hourminute" class="pns"><td colspan="4" align="left"><input type="text" size="1" value="" id="hour" class="px vm" onKeyUp=\'this.value=this.value > 23 ? 23 : zerofill(this.value);controlid.value=controlid.value.replace(/\\d+(\:\\d+)/ig, this.value+"$1")\'>点';
  34. s += '<span id="fullhourselector"><input type="text" size="1" value="" id="minute" class="px vm" onKeyUp=\'this.value=this.value > 59 ? 59 : zerofill(this.value);controlid.value=controlid.value.replace(/(\\d+\:)\\d+/ig, "$1"+this.value)\'>分</span>';
  35. s += '<span id="halfhourselector"><select id="minutehalfhourly" onchange=\'this.value=this.value > 59 ? 59 : zerofill(this.value);controlid.value=controlid.value.replace(/(\\d+\:)\\d+/ig, "$1"+this.value)\'><option value="00">00</option><option value="30">30</option></select>分</span>';
  36. s += '</td><td align="right" colspan="3"><button class="pn" onclick="confirmcalendar();"><em>确定</em></button></td></tr>';
  37. s += '</table></div></div>';
  38. s += '<div id="calendar_year" onclick="doane(event)" style="display: none;z-index:100001;"><div class="col">';
  39. for(var k = 2020; k >= 1931; k--) {
  40. s += k != 2020 && k % 10 == 0 ? '</div><div class="col">' : '';
  41. s += '<a href="javascript:;" onclick="refreshcalendar(' + k + ', mm);$(\'calendar_year\').style.display=\'none\'"><span' + (today.getFullYear() == k ? ' class="calendar_today"' : '') + ' id="calendar_year_' + k + '">' + k + '</span></a><br />';
  42. }
  43. s += '</div></div>';
  44. s += '<div id="calendar_month" onclick="doane(event)" style="display: none;z-index:100001;">';
  45. for(var k = 1; k <= 12; k++) {
  46. s += '<a href="javascript:;" onclick="refreshcalendar(yy, ' + (k - 1) + ');$(\'calendar_month\').style.display=\'none\'"><span' + (today.getMonth()+1 == k ? ' class="calendar_today"' : '') + ' id="calendar_month_' + k + '">' + k + ( k < 10 ? '&nbsp;' : '') + ' 月</span></a><br />';
  47. }
  48. s += '</div>';
  49. if(BROWSER.ie && BROWSER.ie < 7) {
  50. s += '<iframe id="calendariframe" frameborder="0" style="display:none;position:absolute;filter:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=0)"></iframe>';
  51. s += '<iframe id="calendariframe_year" frameborder="0" style="display:none;position:absolute;filter:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=0)"></iframe>';
  52. s += '<iframe id="calendariframe_month" frameborder="0" style="display:none;position:absolute;filter:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=0)"></iframe>';
  53. }
  54. var div = document.createElement('div');
  55. div.innerHTML = s;
  56. $('append_parent').appendChild(div);
  57. document.onclick = function(event) {
  58. closecalendar(event);
  59. };
  60. $('calendar').onclick = function(event) {
  61. doane(event);
  62. $('calendar_year').style.display = 'none';
  63. $('calendar_month').style.display = 'none';
  64. if(BROWSER.ie && BROWSER.ie < 7) {
  65. $('calendariframe_year').style.display = 'none';
  66. $('calendariframe_month').style.display = 'none';
  67. }
  68. };
  69. }
  70. function closecalendar(event) {
  71. $('calendar').style.display = 'none';
  72. $('calendar_year').style.display = 'none';
  73. $('calendar_month').style.display = 'none';
  74. if(BROWSER.ie && BROWSER.ie < 7) {
  75. $('calendariframe').style.display = 'none';
  76. $('calendariframe_year').style.display = 'none';
  77. $('calendariframe_month').style.display = 'none';
  78. }
  79. }
  80. function parsedate(s) {
  81. /(\d+)\-(\d+)\-(\d+)\s*(\d*):?(\d*)/.exec(s);
  82. var m1 = (RegExp.$1 && RegExp.$1 > 1899 && RegExp.$1 < 2101) ? parseFloat(RegExp.$1) : today.getFullYear();
  83. var m2 = (RegExp.$2 && (RegExp.$2 > 0 && RegExp.$2 < 13)) ? parseFloat(RegExp.$2) : today.getMonth() + 1;
  84. var m3 = (RegExp.$3 && (RegExp.$3 > 0 && RegExp.$3 < 32)) ? parseFloat(RegExp.$3) : today.getDate();
  85. var m4 = (RegExp.$4 && (RegExp.$4 > -1 && RegExp.$4 < 24)) ? parseFloat(RegExp.$4) : 0;
  86. var m5 = (RegExp.$5 && (RegExp.$5 > -1 && RegExp.$5 < 60)) ? parseFloat(RegExp.$5) : 0;
  87. /(\d+)\-(\d+)\-(\d+)\s*(\d*):?(\d*)/.exec("0000-00-00 00\:00");
  88. return new Date(m1, m2 - 1, m3, m4, m5);
  89. }
  90. function settime(d) {
  91. if(!addtime) {
  92. $('calendar').style.display = 'none';
  93. $('calendar_month').style.display = 'none';
  94. if(BROWSER.ie && BROWSER.ie < 7) {
  95. $('calendariframe').style.display = 'none';
  96. }
  97. }
  98. controlid.value = yy + "-" + zerofill(mm + 1) + "-" + zerofill(d) + (addtime ? ' ' + zerofill($('hour').value) + ':' + zerofill($((halfhour) ? 'minutehalfhourly' : 'minute').value) : '');
  99. if(typeof calendarrecall == 'function') {
  100. calendarrecall();
  101. } else {
  102. eval(calendarrecall);
  103. }
  104. }
  105. function confirmcalendar() {
  106. if(addtime && controlid.value === '') {
  107. controlid.value = today.getFullYear() + '-' + (today.getMonth() + 1) + '-' + today.getDate() + ' ' + zerofill($('hour').value) + ':' + zerofill($((halfhour) ? 'minutehalfhourly' : 'minute').value);
  108. }
  109. closecalendar();
  110. }
  111. function initclosecalendar() {
  112. var e = getEvent();
  113. var aim = e.target || e.srcElement;
  114. while (aim.parentNode != document.body) {
  115. if (aim.parentNode.id == 'append_parent') {
  116. aim.onclick = function () {closecalendar(e);};
  117. }
  118. aim = aim.parentNode;
  119. }
  120. }
  121. function showcalendar(event, controlid1, addtime1, startdate1, enddate1, halfhour1, recall) {
  122. controlid = controlid1;
  123. addtime = addtime1;
  124. startdate = startdate1 ? parsedate(startdate1) : false;
  125. enddate = enddate1 ? parsedate(enddate1) : false;
  126. currday = controlid.value ? parsedate(controlid.value) : today;
  127. hh = currday.getHours();
  128. ii = currday.getMinutes();
  129. halfhour = halfhour1 ? true : false;
  130. calendarrecall = recall ? recall : null;
  131. var p = fetchOffset(controlid);
  132. $('calendar').style.display = 'block';
  133. $('calendar').style.left = p['left']+'px';
  134. $('calendar').style.top = (p['top'] + 20)+'px';
  135. doane(event);
  136. refreshcalendar(currday.getFullYear(), currday.getMonth());
  137. if(lastcheckedyear != false) {
  138. $('calendar_year_' + lastcheckedyear).className = 'calendar_default';
  139. $('calendar_year_' + today.getFullYear()).className = 'calendar_today';
  140. }
  141. if(lastcheckedmonth != false) {
  142. $('calendar_month_' + lastcheckedmonth).className = 'calendar_default';
  143. $('calendar_month_' + (today.getMonth() + 1)).className = 'calendar_today';
  144. }
  145. $('calendar_year_' + currday.getFullYear()).className = 'calendar_checked';
  146. $('calendar_month_' + (currday.getMonth() + 1)).className = 'calendar_checked';
  147. $('hourminute').style.display = addtime ? '' : 'none';
  148. lastcheckedyear = currday.getFullYear();
  149. lastcheckedmonth = currday.getMonth() + 1;
  150. if(halfhour) {
  151. $('halfhourselector').style.display = '';
  152. $('fullhourselector').style.display = 'none';
  153. } else {
  154. $('halfhourselector').style.display = 'none';
  155. $('fullhourselector').style.display = '';
  156. }
  157. if(BROWSER.ie && BROWSER.ie < 7) {
  158. $('calendariframe').style.top = $('calendar').style.top;
  159. $('calendariframe').style.left = $('calendar').style.left;
  160. $('calendariframe').style.width = $('calendar').offsetWidth;
  161. $('calendariframe').style.height = $('calendar').offsetHeight;
  162. $('calendariframe').style.display = 'block';
  163. }
  164. initclosecalendar();
  165. }
  166. function refreshcalendar(y, m) {
  167. var x = new Date(y, m, 1);
  168. var mv = x.getDay();
  169. var d = x.getDate();
  170. var dd = null;
  171. yy = x.getFullYear();
  172. mm = x.getMonth();
  173. $("year").innerHTML = yy;
  174. $("month").innerHTML = mm + 1 > 9 ? (mm + 1) : '0' + (mm + 1);
  175. for(var i = 1; i <= mv; i++) {
  176. dd = $("d" + i);
  177. dd.innerHTML = "&nbsp;";
  178. dd.className = "";
  179. }
  180. while(x.getMonth() == mm) {
  181. dd = $("d" + (d + mv));
  182. dd.style.cursor = 'pointer';
  183. dd.onclick = function () {
  184. settime(this.childNodes[0].innerHTML);
  185. doane();
  186. };
  187. dd.innerHTML = '<a href="javascript:;">' + d + '</a>';
  188. if(x.getTime() < today.getTime() || (enddate && x.getTime() > enddate.getTime()) || (startdate && x.getTime() < startdate.getTime())) {
  189. dd.className = 'calendar_expire';
  190. } else {
  191. dd.className = 'calendar_default';
  192. }
  193. if(x.getFullYear() == today.getFullYear() && x.getMonth() == today.getMonth() && x.getDate() == today.getDate()) {
  194. dd.className = 'calendar_today';
  195. dd.firstChild.title = '今天';
  196. }
  197. if(x.getFullYear() == currday.getFullYear() && x.getMonth() == currday.getMonth() && x.getDate() == currday.getDate()) {
  198. dd.className = 'calendar_checked';
  199. }
  200. x.setDate(++d);
  201. }
  202. while(d + mv <= 42) {
  203. dd = $("d" + (d + mv));
  204. dd.innerHTML = "&nbsp;";
  205. d++;
  206. }
  207. if(addtime) {
  208. $('hour').value = zerofill(hh);
  209. $('minute').value = zerofill(ii);
  210. }
  211. }
  212. function showdiv(id) {
  213. var p = fetchOffset($(id));
  214. $('calendar_' + id).style.left = p['left']+'px';
  215. $('calendar_' + id).style.top = (p['top'] + 16)+'px';
  216. $('calendar_' + id).style.display = 'block';
  217. if(BROWSER.ie && BROWSER.ie < 7) {
  218. $('calendariframe_' + id).style.top = $('calendar_' + id).style.top;
  219. $('calendariframe_' + id).style.left = $('calendar_' + id).style.left;
  220. $('calendariframe_' + id).style.width = $('calendar_' + id).offsetWidth;
  221. $('calendariframe_' + id ).style.height = $('calendar_' + id).offsetHeight;
  222. $('calendariframe_' + id).style.display = 'block';
  223. }
  224. }
  225. function zerofill(s) {
  226. var s = parseFloat(s.toString().replace(/(^[\s0]+)|(\s+$)/g, ''));
  227. s = isNaN(s) ? 0 : s;
  228. return (s < 10 ? '0' : '') + s.toString();
  229. }
  230. if(!BROWSER.other) {
  231. loadcss('forum_calendar');
  232. loadcalendar();
  233. }