jquery.fullcalendar.js 43 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064
  1. /**
  2. * calendar - jQuery EasyUI
  3. *
  4. * Copyright (c) 2009-2013 www.jeasyui.com. All rights reserved.
  5. *
  6. * Licensed under the GPL or commercial licenses
  7. * To use it on other terms please contact us: jeasyui@gmail.com
  8. * http://www.gnu.org/licenses/gpl.txt
  9. * http://www.jeasyui.com/license_commercial.php
  10. * 二次开发 ____′↘夏悸
  11. * http://bbs.btboys.com Easyui中文社区
  12. */
  13. (function ($) {
  14. /*****************************************************************************
  15. /*****************************************************************************
  16. 日期资料
  17. *****************************************************************************/
  18. var ttime = 0;
  19. var detail;
  20. var hideTimer;
  21. var Today = new Date();
  22. var tY = Today.getFullYear();
  23. var tM = Today.getMonth();
  24. var tD = Today.getDate();
  25. var tInfo = new Array(
  26. 0x04bd8, 0x04ae0, 0x0a570, 0x054d5, 0x0d260, 0x0d950, 0x16554, 0x056a0, 0x09ad0, 0x055d2,
  27. 0x04ae0, 0x0a5b6, 0x0a4d0, 0x0d250, 0x1d255, 0x0b540, 0x0d6a0, 0x0ada2, 0x095b0, 0x14977,
  28. 0x04970, 0x0a4b0, 0x0b4b5, 0x06a50, 0x06d40, 0x1ab54, 0x02b60, 0x09570, 0x052f2, 0x04970,
  29. 0x06566, 0x0d4a0, 0x0ea50, 0x06e95, 0x05ad0, 0x02b60, 0x186e3, 0x092e0, 0x1c8d7, 0x0c950,
  30. 0x0d4a0, 0x1d8a6, 0x0b550, 0x056a0, 0x1a5b4, 0x025d0, 0x092d0, 0x0d2b2, 0x0a950, 0x0b557,
  31. 0x06ca0, 0x0b550, 0x15355, 0x04da0, 0x0a5b0, 0x14573, 0x052b0, 0x0a9a8, 0x0e950, 0x06aa0,
  32. 0x0aea6, 0x0ab50, 0x04b60, 0x0aae4, 0x0a570, 0x05260, 0x0f263, 0x0d950, 0x05b57, 0x056a0,
  33. 0x096d0, 0x04dd5, 0x04ad0, 0x0a4d0, 0x0d4d4, 0x0d250, 0x0d558, 0x0b540, 0x0b6a0, 0x195a6,
  34. 0x095b0, 0x049b0, 0x0a974, 0x0a4b0, 0x0b27a, 0x06a50, 0x06d40, 0x0af46, 0x0ab60, 0x09570,
  35. 0x04af5, 0x04970, 0x064b0, 0x074a3, 0x0ea50, 0x06b58, 0x055c0, 0x0ab60, 0x096d5, 0x092e0,
  36. 0x0c960, 0x0d954, 0x0d4a0, 0x0da50, 0x07552, 0x056a0, 0x0abb7, 0x025d0, 0x092d0, 0x0cab5,
  37. 0x0a950, 0x0b4a0, 0x0baa4, 0x0ad50, 0x055d9, 0x04ba0, 0x0a5b0, 0x15176, 0x052b0, 0x0a930,
  38. 0x07954, 0x06aa0, 0x0ad50, 0x05b52, 0x04b60, 0x0a6e6, 0x0a4e0, 0x0d260, 0x0ea65, 0x0d530,
  39. 0x05aa0, 0x076a3, 0x096d0, 0x04bd7, 0x04ad0, 0x0a4d0, 0x1d0b6, 0x0d250, 0x0d520, 0x0dd45,
  40. 0x0b5a0, 0x056d0, 0x055b2, 0x049b0, 0x0a577, 0x0a4b0, 0x0aa50, 0x1b255, 0x06d20, 0x0ada0,
  41. 0x14b63);
  42. var solarMonth = new Array(31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31);
  43. var Gan = new Array("甲", "乙", "丙", "丁", "戊", "己", "庚", "辛", "壬", "癸");
  44. var Zhi = new Array("子", "丑", "寅", "卯", "辰", "巳", "午", "未", "申", "酉", "戌", "亥");
  45. var Animals = new Array("鼠", "牛", "虎", "兔", "龙", "蛇", "马", "羊", "猴", "鸡", "狗", "猪");
  46. var solarTerm = new Array("小寒", "大寒", "立春", "雨水", "惊蛰", "春分", "清明", "谷雨", "立夏", "小满", "芒种", "夏至", "小暑", "大暑", "立秋", "处暑", "白露", "秋分", "寒露", "霜降", "立冬", "小雪", "大雪", "冬至");
  47. var sTermInfo = new Array(0, 21208, 42467, 63836, 85337, 107014, 128867, 150921, 173149, 195551, 218072, 240693, 263343, 285989, 308563, 331033, 353350, 375494, 397447, 419210, 440795, 462224, 483532, 504758);
  48. var nStr1 = new Array('日', '一', '二', '三', '四', '五', '六', '七', '八', '九', '十');
  49. var nStr2 = new Array('初', '十', '廿', '卅', '□');
  50. var monthName = new Array("正月", "二月", "三月", "四月", "五月", "六月", "七月", "八月", "九月", "十月", "冬月", "腊月");
  51. /*****************************************************************************
  52. 日期计算
  53. *****************************************************************************/
  54. //====================================== 返回农历 y年的总天数
  55. function lYearDays(y) {
  56. var i,
  57. sum = 348;
  58. for (i = 0x8000; i > 0x8; i >>= 1)
  59. sum += (tInfo[y - 1900] & i) ? 1 : 0;
  60. return (sum + leapDays(y));
  61. }
  62. //====================================== 返回农历 y年闰月的天数
  63. function leapDays(y) {
  64. if (leapMonth(y))
  65. return ((tInfo[y - 1900] & 0x10000) ? 30 : 29);
  66. else
  67. return (0);
  68. }
  69. //====================================== 返回农历 y年闰哪个月 1-12 , 没闰返回 0
  70. function leapMonth(y) {
  71. return (tInfo[y - 1900] & 0xf);
  72. }
  73. //====================================== 返回农历 y年m月的总天数
  74. function monthDays(y, m) {
  75. return ((tInfo[y - 1900] & (0x10000 >> m)) ? 30 : 29);
  76. }
  77. //====================================== 算出农历, 传入日期控件, 返回农历日期控件
  78. // 该控件属性有 .year .month .day .isLeap
  79. function Lunar(objDate) {
  80. var i,
  81. leap = 0,
  82. temp = 0;
  83. var offset = (Date.UTC(objDate.getFullYear(), objDate.getMonth(), objDate.getDate()) - Date.UTC(1900, 0, 31)) / 86400000;
  84. for (i = 1900; i < 2050 && offset > 0; i++) {
  85. temp = lYearDays(i);
  86. offset -= temp;
  87. }
  88. if (offset < 0) {
  89. offset += temp;
  90. i--;
  91. }
  92. this.year = i;
  93. leap = leapMonth(i); //闰哪个月
  94. this.isLeap = false;
  95. for (i = 1; i < 13 && offset > 0; i++) {
  96. //闰月
  97. if (leap > 0 && i == (leap + 1) && this.isLeap == false) {
  98. --i;
  99. this.isLeap = true;
  100. temp = leapDays(this.year);
  101. } else {
  102. temp = monthDays(this.year, i);
  103. }
  104. //解除闰月
  105. if (this.isLeap == true && i == (leap + 1))
  106. this.isLeap = false;
  107. offset -= temp;
  108. }
  109. if (offset == 0 && leap > 0 && i == leap + 1)
  110. if (this.isLeap) {
  111. this.isLeap = false;
  112. } else {
  113. this.isLeap = true;
  114. --i;
  115. }
  116. if (offset < 0) {
  117. offset += temp;
  118. --i;
  119. }
  120. this.month = i;
  121. this.day = offset + 1;
  122. }
  123. //==============================返回公历 y年某m+1月的天数
  124. function solarDays(y, m) {
  125. if (m == 1)
  126. return (((y % 4 == 0) && (y % 100 != 0) || (y % 400 == 0)) ? 29 : 28);
  127. else
  128. return (solarMonth[m]);
  129. }
  130. //============================== 传入 offset 返回干支, 0=甲子
  131. function cyclical(num) {
  132. return (Gan[num % 10] + Zhi[num % 12]);
  133. }
  134. //============================== 阴历属性
  135. function calElement(sYear, sMonth, sDay, week, lYear, lMonth, lDay, isLeap, cYear, cMonth, cDay) {
  136. this.isToday = false;
  137. //瓣句
  138. this.sYear = sYear; //公元年4位数字
  139. this.sMonth = sMonth; //公元月数字
  140. this.sDay = sDay; //公元日数字
  141. this.week = week; //星期, 1个中文
  142. //农历
  143. this.lYear = lYear; //公元年4位数字
  144. this.lMonth = lMonth; //农历月数字
  145. this.lDay = lDay; //农历日数字
  146. this.isLeap = isLeap; //是否为农历闰月?
  147. //八字
  148. this.cYear = cYear; //年柱, 2个中文
  149. this.cMonth = cMonth; //月柱, 2个中文
  150. this.cDay = cDay; //日柱, 2个中文
  151. this.color = '';
  152. this.lunarFestival = ''; //农历节日
  153. this.solarFestival = ''; //公历节日
  154. this.solarTerms = ''; //节气
  155. }
  156. //===== 某年的第n个节气为几日(从0小寒起算)
  157. function sTerm(y, n) {
  158. if (y == 2009 && n == 2) {
  159. sTermInfo[n] = 43467
  160. }
  161. var offDate = new Date((31556925974.7 * (y - 1900) + sTermInfo[n] * 60000) + Date.UTC(1900, 0, 6, 2, 5));
  162. return (offDate.getUTCDate());
  163. }
  164. //============================== 返回阴历控件 (y年,m+1月)
  165. /*
  166. 功能说明: 返回整个月的日期资料控件
  167. 使用方式: OBJ = new calendar(年,零起算月);
  168. OBJ.length 返回当月最大日
  169. OBJ.firstWeek 返回当月一日星期
  170. 由 OBJ[日期].属性名称 即可取得各项值
  171. OBJ[日期].isToday 返回是否为今日 true 或 false
  172. 其他 OBJ[日期] 属性参见 calElement() 中的注解
  173. */
  174. function Calendar(y, m) {
  175. var sDObj,
  176. lDObj,
  177. lY,
  178. lM,
  179. lD = 1,
  180. lL,
  181. lX = 0,
  182. tmp1,
  183. tmp2,
  184. tmp3;
  185. var cY,
  186. cM,
  187. cD; //年柱,月柱,日柱
  188. var lDPOS = new Array(3);
  189. var n = 0;
  190. var firstLM = 0;
  191. sDObj = new Date(y, m, 1, 0, 0, 0, 0); //当月一日日期
  192. this.length = solarDays(y, m); //公历当月天数
  193. this.firstWeek = sDObj.getDay(); //公历当月1日星期几
  194. ////////年柱 1900年立春后为庚子年(60进制36)
  195. if (m < 2)
  196. cY = cyclical(y - 1900 + 36 - 1);
  197. else
  198. cY = cyclical(y - 1900 + 36);
  199. var term2 = sTerm(y, 2); //立春日期
  200. ////////月柱 1900年1月小寒以前为 丙子月(60进制12)
  201. var firstNode = sTerm(y, m * 2) //返回当月「节」为几日开始
  202. cM = cyclical((y - 1900) * 12 + m + 12);
  203. //当月一日与 1900/1/1 相差天数
  204. //1900/1/1与 1970/1/1 相差25567日, 1900/1/1 日柱为甲戌日(60进制10)
  205. var dayCyclical = Date.UTC(y, m, 1, 0, 0, 0, 0) / 86400000 + 25567 + 10;
  206. for (var i = 0; i < this.length; i++) {
  207. if (lD > lX) {
  208. sDObj = new Date(y, m, i + 1); //当月一日日期
  209. lDObj = new Lunar(sDObj); //农历
  210. lY = lDObj.year; //农历年
  211. lM = lDObj.month; //农历月
  212. lD = lDObj.day; //农历日
  213. lL = lDObj.isLeap; //农历是否闰月
  214. lX = lL ? leapDays(lY) : monthDays(lY, lM); //农历当月最后一天
  215. if (n == 0)
  216. firstLM = lM;
  217. lDPOS[n++] = i - lD + 1;
  218. }
  219. //依节气调整二月分的年柱, 以立春为界
  220. /*
  221. //PM提出线上2月3日,初一不是庚寅年,应该是辛卯年。
  222. by yuji
  223. 这里firstNode是指农历每月的节气所在的日期,用这个标志判断
  224. 农历每月起始日天干地支是错误的,应当用每月的农历初一所在日确定
  225. 下月的天干地支。农历每月初一都要重新计算一下天干地支。
  226. */
  227. if (m == 1 && ((i + 1) == term2 || lD == 1))
  228. cY = cyclical(y - 1900 + 36);
  229. //依节气月柱, 以「节」为界
  230. //if((i+1)==firstNode) cM = cyclical((y-1900)*12+m+13);
  231. /*
  232. by yuji
  233. 这里firstNode是指农历每月的节气所在的日期,用这个标志判断
  234. 农历每月起始日天干地支是错误的,应当用每月的农历初一所在日确定
  235. 下月的天干地支。农历每月初一都要重新计算一下天干地支。
  236. */
  237. if (lD == 1) {
  238. cM = cyclical((y - 1900) * 12 + m + 13);
  239. }
  240. //日柱
  241. cD = cyclical(dayCyclical + i);
  242. //sYear,sMonth,sDay,week,
  243. //lYear,lMonth,lDay,isLeap,
  244. //cYear,cMonth,cDay
  245. this[i] = new calElement(y, m + 1, i + 1, nStr1[(i + this.firstWeek) % 7],
  246. lY, lM, lD++, lL,
  247. cY, cM, cD);
  248. }
  249. //节气
  250. tmp1 = sTerm(y, m * 2) - 1;
  251. tmp2 = sTerm(y, m * 2 + 1) - 1;
  252. this[tmp1].solarTerms = solarTerm[m * 2];
  253. this[tmp2].solarTerms = solarTerm[m * 2 + 1];
  254. //guohao
  255. if (y == 2009 && m == 1) {
  256. if (tD == 3) {
  257. this[tmp1].solarTerms = ''
  258. //this[tmp2].solarTerms = ''
  259. } else if (tD == 4) {
  260. this[tmp1].solarTerms = '立春'
  261. //this[tmp2].solarTerms = ''
  262. }
  263. }
  264. if (m == 3)
  265. this[tmp1].color = 'red'; //清明颜色
  266. //今日
  267. if (y == tY && m == tM)
  268. this[tD - 1].isToday = true;
  269. }
  270. //======================================= 返回该年的复活节(春分后第一次满月周后的第一主日)
  271. function easter(y) {
  272. var term2 = sTerm(y, 5); //取得春分日期
  273. var dayTerm2 = new Date(Date.UTC(y, 2, term2, 0, 0, 0, 0)); //取得春分的公历日期控件(春分一定出现在3月)
  274. var lDayTerm2 = new Lunar(dayTerm2); //取得取得春分农历
  275. if (lDayTerm2.day < 15) //取得下个月圆的相差天数
  276. var lMlen = 15 - lDayTerm2.day;
  277. else
  278. var lMlen = (lDayTerm2.isLeap ? leapDays(y) : monthDays(y, lDayTerm2.month)) - lDayTerm2.day + 15;
  279. //一天等于 1000*60*60*24 = 86400000 毫秒
  280. var l15 = new Date(dayTerm2.getTime() + 86400000 * lMlen); //求出第一次月圆为公历几日
  281. var dayEaster = new Date(l15.getTime() + 86400000 * (7 - l15.getUTCDay())); //求出下个周日
  282. this.m = dayEaster.getUTCMonth();
  283. this.d = dayEaster.getUTCDate();
  284. }
  285. //====================== 中文日期
  286. function cDay(d, m,dt) {
  287. var s;
  288. switch (d) {
  289. case 1:
  290. s = monthName[m - 1];
  291. if(dt){
  292. s = '初一';
  293. }
  294. break;
  295. case 10:
  296. s = '初十';
  297. break;
  298. case 20:
  299. s = '二十';
  300. break;
  301. case 30:
  302. s = '三十';
  303. break;
  304. default:
  305. s = nStr2[Math.floor(d / 10)];
  306. s += nStr1[d % 10];
  307. }
  308. return (s);
  309. }
  310. var detailTpl = '<div style="position: absolute;visibility: hidden;"><div></div></div>';
  311. var favTpl = '<font color="#000000" style="font-size:9pt;">{fav}</font>';
  312. function setSize(target) {
  313. var opts = $.data(target, 'fullCalendar').options;
  314. var t = $(target);
  315. if (opts.fit == true) {
  316. var p = t.parent();
  317. opts.width = p.width();
  318. opts.height = p.height();
  319. }
  320. var header = t.find('.calendar-header');
  321. t._outerWidth(opts.width);
  322. t._outerHeight(opts.height);
  323. t.find('.calendar-body')._outerHeight(t.height() - header._outerHeight());
  324. }
  325. //初始化方法
  326. function init(target) {
  327. $(target).addClass('calendar').wrapInner(
  328. '<div class="calendar-header">' +
  329. /*'<a class="calendar-prevmonth"></a>' +
  330. '<a class="calendar-nextmonth"></a>' +
  331. '<a class="calendar-prevyear"></a>' +
  332. '<a class="calendar-nextyear"></a>' +
  333. '<a class="calendar-title">' +
  334. '<span>Aprial 2010</span>' +
  335. '</a>' +*/
  336. '<a class="calendar-prevyear"></a>'+
  337. '&nbsp;'+
  338. '<a class="calendar-year"></a>'+
  339. '&nbsp;'+
  340. '<a class="calendar-nextyear"></a>'+
  341. '&nbsp;'+
  342. '<a class="calendar-prevmonth"></a>'+
  343. '&nbsp;'+
  344. '<a class="calendar-month"></a>'+
  345. '&nbsp;'+
  346. '<a class="calendar-nextmonth"></a>'+
  347. '<a class="calendar-title">'+
  348. '<span>Aprial 2010</span>'+
  349. '</a>'+
  350. '<a onclick="add()" style="position:absolute;right:3px;top:0px;cursor:pointer;"><img src="../../styles/blue/images/xinzeng2.png" /></ a>'+
  351. '</div>' +
  352. '<div class="calendar-body fullcalendar-body">' +
  353. '<div class="calendar-menu">' +
  354. '<div class="calendar-menu-year-inner">' +
  355. '<span class="calendar-menu-prev"></span>' +
  356. '<span><input class="calendar-menu-year" type="text"></input></span>' +
  357. '<span class="calendar-menu-next"></span>' +
  358. '</div>' +
  359. '<div class="calendar-menu-month-inner">' +
  360. '</div>' +
  361. '</div>' +
  362. '</div>');
  363. detail = $('div.fullcalendar-detail');
  364. //鼠标滑过显示农历等信息
  365. if (!detail.length) {
  366. }
  367. $(target).find('.calendar-title span').hover(
  368. function () {
  369. $(this).addClass('calendar-menu-hover');
  370. },
  371. function () {
  372. $(this).removeClass('calendar-menu-hover');
  373. }).click(function () {
  374. var menu = $(target).find('.calendar-menu');
  375. if (menu.is(':visible')) {
  376. menu.hide();
  377. } else {
  378. showSelectMenus(target);
  379. }
  380. });
  381. $('.calendar-prevmonth,.calendar-nextmonth,.calendar-prevyear,.calendar-nextyear', target).hover(
  382. function () {
  383. $(this).addClass('calendar-nav-hover');
  384. },
  385. function () {
  386. $(this).removeClass('calendar-nav-hover');
  387. });
  388. $(target).find('.calendar-nextmonth').click(function () {
  389. showMonth(target, 1);
  390. });
  391. $(target).find('.calendar-prevmonth').click(function () {
  392. showMonth(target, -1);
  393. });
  394. $(target).find('.calendar-nextyear').click(function () {
  395. showYear(target, 1);
  396. });
  397. $(target).find('.calendar-prevyear').click(function () {
  398. showYear(target, -1);
  399. });
  400. $(target).bind('_resize', function () {
  401. var opts = $.data(target, 'fullCalendar').options;
  402. if (opts.fit == true) {
  403. setSize(target);
  404. }
  405. return false;
  406. });
  407. //将打卡记录显示在日历上
  408. function punch(){
  409. var url="${ctx}/platform/console/getPunchByUserId.ht";
  410. $(target).find
  411. }
  412. }
  413. /**
  414. * show the calendar corresponding to the current month 点击切换 显示对应于当前的日历月。
  415. */
  416. function showMonth(target, delta) {
  417. var opts = $.data(target, 'fullCalendar').options;
  418. opts.month += delta;
  419. if (opts.month > 12) {
  420. opts.year++;
  421. opts.month = 1;
  422. } else if (opts.month < 1) {
  423. opts.year--;
  424. opts.month = 12;
  425. }
  426. show(target);
  427. var menu = $(target).find('.calendar-menu-month-inner');
  428. menu.find('td.calendar-selected').removeClass('calendar-selected');
  429. menu.find('td:eq(' + (opts.month - 1) + ')').addClass('calendar-selected');
  430. }
  431. /**
  432. * show the calendar corresponding to the current year. 点击切换 显示相应日历 年
  433. */
  434. function showYear(target, delta) {
  435. var opts = $.data(target, 'fullCalendar').options;
  436. opts.year += delta;
  437. show(target);
  438. var menu = $(target).find('.calendar-menu-year');
  439. menu.val(opts.year);
  440. }
  441. /**
  442. * show the select menu that can change year or month, if the menu is not be created then create it.显示可以改变年或月的选择菜单,如果不创建菜单然后创建它。
  443. */
  444. function showSelectMenus(target) {
  445. var opts = $.data(target, 'fullCalendar').options;
  446. $(target).find('.calendar-menu').show();
  447. if ($(target).find('.calendar-menu-month-inner').is(':empty')) {
  448. $(target).find('.calendar-menu-month-inner').empty();
  449. var t = $('<table cellspacing="5" cellpadding="5" ></table>').appendTo($(target).find('.calendar-menu-month-inner'));
  450. var idx = 0;
  451. for (var i = 0; i < 3; i++) {
  452. var tr = $('<tr></tr>').appendTo(t);
  453. for (var j = 0; j < 4; j++) {
  454. $('<td class="calendar-menu-month"></td>').html(opts.months[idx++]).attr('abbr', idx).appendTo(tr);
  455. }
  456. }
  457. $(target).find('.calendar-menu-prev,.calendar-menu-next').hover(
  458. function () {
  459. $(this).addClass('calendar-menu-hover');
  460. },
  461. function () {
  462. $(this).removeClass('calendar-menu-hover');
  463. });
  464. $(target).find('.calendar-menu-next').click(function () {
  465. var y = $(target).find('.calendar-menu-year');
  466. if (!isNaN(y.val())) {
  467. y.val(parseInt(y.val()) + 1);
  468. }
  469. });
  470. $(target).find('.calendar-menu-prev').click(function () {
  471. var y = $(target).find('.calendar-menu-year');
  472. if (!isNaN(y.val())) {
  473. y.val(parseInt(y.val() - 1));
  474. }
  475. });
  476. $(target).find('.calendar-menu-year').keypress(function (e) {
  477. if (e.keyCode == 13) {
  478. setDate();
  479. }
  480. });
  481. $(target).find('.calendar-menu-month').hover(
  482. function () {
  483. $(this).addClass('calendar-menu-hover');
  484. },
  485. function () {
  486. $(this).removeClass('calendar-menu-hover');
  487. }).click(function () {
  488. var menu = $(target).find('.calendar-menu');
  489. menu.find('.calendar-selected').removeClass('calendar-selected');
  490. $(this).addClass('calendar-selected');
  491. setDate();
  492. });
  493. }
  494. function setDate() {
  495. var menu = $(target).find('.calendar-menu');
  496. var year = menu.find('.calendar-menu-year').val();
  497. var month = menu.find('.calendar-selected').attr('abbr');
  498. if (!isNaN(year)) {
  499. opts.year = parseInt(year);
  500. opts.month = parseInt(month);
  501. show(target);
  502. }
  503. menu.hide();
  504. }
  505. var body = $(target).find('.calendar-body');
  506. var sele = $(target).find('.calendar-menu');
  507. var seleYear = sele.find('.calendar-menu-year-inner');
  508. var seleMonth = sele.find('.calendar-menu-month-inner');
  509. seleYear.find('input').val(opts.year).focus();
  510. seleMonth.find('td.calendar-selected').removeClass('calendar-selected');
  511. seleMonth.find('td:eq(' + (opts.month - 1) + ')').addClass('calendar-selected');
  512. sele._outerWidth(body._outerWidth());
  513. sele._outerHeight(body._outerHeight());
  514. seleMonth._outerHeight(sele.height() - seleYear._outerHeight());
  515. }
  516. /**
  517. * get weeks data. 获得周数据
  518. */
  519. function getWeeks(target, year, month) {
  520. var opts = $.data(target, 'fullCalendar').options;
  521. var dates = [];
  522. var lastDay = new Date(year, month, 0).getDate();
  523. for (var i = 1; i <= lastDay; i++)
  524. dates.push([year, month, i]);
  525. // group date by week 周数组
  526. var weeks = [],
  527. week = [];
  528. // var memoDay = 0;
  529. var memoDay = -1;
  530. while (dates.length > 0) {
  531. var date = dates.shift();
  532. week.push(date);
  533. var day = new Date(date[0], date[1] - 1, date[2]).getDay();
  534. if (memoDay == day) {
  535. day = 0;
  536. } else if (day == (opts.firstDay == 0 ? 7 : opts.firstDay) - 1) {
  537. weeks.push(week);
  538. week = [];
  539. }
  540. memoDay = day;
  541. }
  542. if (week.length) {
  543. weeks.push(week);
  544. }
  545. var firstWeek = weeks[0];
  546. if (firstWeek.length < 7) {
  547. while (firstWeek.length < 7) {
  548. var firstDate = firstWeek[0];
  549. var date = new Date(firstDate[0], firstDate[1] - 1, firstDate[2] - 1)
  550. firstWeek.unshift([date.getFullYear(), date.getMonth() + 1, date.getDate()]);
  551. }
  552. } else {
  553. var firstDate = firstWeek[0];
  554. var week = [];
  555. for (var i = 1; i <= 7; i++) {
  556. var date = new Date(firstDate[0], firstDate[1] - 1, firstDate[2] - i);
  557. week.unshift([date.getFullYear(), date.getMonth() + 1, date.getDate()]);
  558. }
  559. weeks.unshift(week);
  560. }
  561. var lastWeek = weeks[weeks.length - 1];
  562. while (lastWeek.length < 7) {
  563. var lastDate = lastWeek[lastWeek.length - 1];
  564. var date = new Date(lastDate[0], lastDate[1] - 1, lastDate[2] + 1);
  565. lastWeek.push([date.getFullYear(), date.getMonth() + 1, date.getDate()]);
  566. }
  567. if (weeks.length < 6) {
  568. var lastDate = lastWeek[lastWeek.length - 1];
  569. var week = [];
  570. for (var i = 1; i <= 7; i++) {
  571. var date = new Date(lastDate[0], lastDate[1] - 1, lastDate[2] + i);
  572. week.push([date.getFullYear(), date.getMonth() + 1, date.getDate()]);
  573. }
  574. weeks.push(week);
  575. }
  576. return weeks;
  577. }
  578. /**
  579. * 从数据库获取数据选择工作日和休息日
  580. */
  581. function checkHo_day(year,month){
  582. var jsondata=null;
  583. var nowDay = new Date();
  584. var nowY = year;
  585. var nowM = month;
  586. var daysList="";
  587. $.post(contextPath+"/platform/jiejiari/jieJiaRi/initCalendar.ht",{ho_month:nowM,ho_year:nowY},function(json){
  588. jsondata=JSON.parse(json);
  589. for(var i=0;i<jsondata.length;i++){
  590. var a=jsondata[i].ho_year;
  591. var b=jsondata[i].ho_month;
  592. var c=jsondata[i].ho_day;
  593. if(b.substr(0,1)=="0"){
  594. b=b.substr(1);
  595. }
  596. if(c.substr(0,1)=="0"){
  597. c=c.substr(1);
  598. }
  599. myday=a+"-"+b+"-"+c;
  600. if(jsondata[i].ho_type=="1"){
  601. $("#"+myday+" option[value='1']").attr("selected", true);
  602. }else{
  603. $("#"+myday+" option[value='0']").attr("selected", true);
  604. }
  605. }
  606. });
  607. }
  608. /**
  609. * show the calendar day. 显示日历天
  610. */
  611. function show(target) {
  612. var opts = $.data(target, 'fullCalendar').options;
  613. if (opts.year > 1874 && opts.year < 1909)
  614. yDisplay = '光绪' + (((opts.year - 1874) == 1) ? '元' : opts.year - 1874);
  615. if (opts.year > 1908 && opts.year < 1912)
  616. yDisplay = '宣统' + (((opts.year - 1908) == 1) ? '元' : opts.year - 1908);
  617. if (opts.year > 1911)
  618. yDisplay = '建国' + (((opts.year - 1949) == 1) ? '元' : opts.year - 1949);
  619. //$(target).find('.calendar-title span').html(opts.months[opts.month - 1] + ' ' + opts.year + ' ' + yDisplay + '年 农历 ' + cyclical(opts.year - 1900 + 36) + '年 【' + Animals[(opts.year - 4) % 12] + '年】');
  620. // 这是日历头部
  621. $(target).find('.calendar-year').html(opts.year+'年');
  622. $(target).find('.calendar-month').html(opts.months[opts.month - 1]+'月');
  623. $(target).find('.calendar-title span').html(yDisplay + '年 农历 ' + cyclical(opts.year - 1900 + 36) + '年 【' + Animals[(opts.year - 4) % 12] + '年】')
  624. // $(target).find('.calendar-title span').html('');
  625. var body = $(target).find('div.calendar-body');
  626. body.find('>table').remove();
  627. var t = $('<table cellspacing="0" cellpadding="0" border="0"><thead></thead><tbody></tbody></table>').prependTo(body);
  628. var tr = $('<tr></tr>').appendTo(t.find('thead'));
  629. for (var i = opts.firstDay; i < opts.weeks.length; i++) {
  630. tr.append('<th>' + opts.weeks[i] + '</th>');
  631. }
  632. for (var i = 0; i < opts.firstDay; i++) {
  633. tr.append('<th>' + opts.weeks[i] + '</th>');
  634. }
  635. var weeks = getWeeks(target, opts.year, opts.month);
  636. var currentCa = new Calendar(opts.year, opts.month - 1);
  637. for (var i = 0; i < weeks.length; i++) {
  638. var week = weeks[i];
  639. var tr = $('<tr></tr>').appendTo(t.find('tbody'));
  640. for (var j = 0; j < week.length; j++) {
  641. var day = week[j];
  642. //<i class="shang1"></i><u class="xia2"></u>
  643. var dayHtml = '<i></i><u ></u><span>' + day[2];
  644. var info = null;
  645. var str = '';
  646. // if(opts.weeks[j]=='星期六'||opts.weeks[j]=='星期日'){
  647. // str+="<select id='"+day[0]+"-"+day[1]+"-"+day[2]+"' name='workType'><option style='color:red' value='1' >休息日</option><option value='0'>工作日</option></select>";
  648. // }else{
  649. // str+="<select id='"+day[0]+"-"+day[1]+"-"+day[2]+"' name='workType'><option value='0'>工作日</option><option style='color:red' value='1' >休息日</option></select>";
  650. // }
  651. if (opts.month == day[1]) {
  652. info = currentCa[day[2] - 1];
  653. if (info.color) {
  654. var color = 'color="' + info.color + '"';
  655. dayHtml = '<span ' + color + '>' + day[2];
  656. }
  657. dayHtml += '</span>';
  658. if (opts.lunarDay) {
  659. dayHtml += "<br/>";
  660. if (opts.solarTerms && info.solarTerms) {
  661. dayHtml += '<span color="#2B91D5">' + info.solarTerms + '</span><br/>'+str;
  662. } else {
  663. dayHtml += '<span size="2" style="font-size:9pt">' + cDay(info.lDay, info.lMonth) + '</span><br/>'+str;
  664. }
  665. }
  666. }
  667. // alert(str);
  668. var day = $('<td class="posi_td calendar-day fullcalendar-day calendar-other-month" onclick="onSelect(this)"></td>').data('info', info).attr('abbr', day[0] + '-' + day[1] + '-' + day[2]).html(dayHtml).appendTo(tr);
  669. if (info && (info.lunarFestival || info.solarFestival)) {
  670. day.addClass('festival');
  671. }
  672. day.hover(function (e) {
  673. clearTimeout(hideTimer);
  674. var inf = $(this).data('info');
  675. if (inf) {
  676. var ct = '<font color="#ffffff" style="font-size:9pt;">' + inf.sYear
  677. + ' 年 ' + inf.sMonth + ' 月 ' + inf.sDay + ' 日<br>星期' + inf.week
  678. + '<br><font color="white">农历 ' + monthName[inf.lMonth - 1] + ' 月 ' + cDay(inf.lDay, inf.lMonth,true)
  679. + ' 日</font><br><font color="yellow">' + inf.cYear + '年 ' + inf.cMonth + '月 ' + inf.cDay + '日</font></font>';
  680. detail.html(ct);
  681. detail.css(calculatePos.call(target, detail, e.currentTarget)).fadeIn();
  682. if (inf.lunarFestival) {
  683. detail.append('<div class="lunarFestival">' + inf.lunarFestival + '</div>');
  684. }
  685. if (inf.solarFestival) {
  686. detail.append('<div class="solarFestival">' + inf.solarFestival + '</div>');
  687. }
  688. } else {
  689. detail.hide();
  690. }
  691. }, function () {
  692. hideTimer = setTimeout(function () {
  693. $('div.fullcalendar-detail').hide();
  694. }, 500);
  695. });
  696. }
  697. }
  698. t.find('td[abbr^="' + opts.year + '-' + opts.month + '"]').removeClass('calendar-other-month');
  699. var now = new Date();
  700. var today = now.getFullYear() + '-' + (now.getMonth() + 1) + '-' + now.getDate();
  701. var current = opts.current.getFullYear() + '-' + (opts.current.getMonth() + 1) + '-' + opts.current.getDate();
  702. //获取服务器时间的today 李猛20190422ADD
  703. $.post('getServerTime.ht',{},function(res){
  704. var json =JSON.parse(res);
  705. today = json.message;
  706. current = json.message;
  707. });
  708. t.find('td[abbr="' + today + '"]').addClass('calendar-today');
  709. t.find('td[abbr="' + current + '"]').addClass('calendar-selected').css('backgroundColor', 'rgb(129, 208, 242)');
  710. // if (opts.current) {
  711. // t.find('.calendar-selected').removeClass('calendar-selected').css('backgroundColor', '');
  712. // var current = opts.current.getFullYear() + '-' + (opts.current.getMonth() + 1) + '-' + opts.current.getDate();
  713. // // alert(current);
  714. // }
  715. // calulate the saturday and sunday index 日历悬浮样式和点击样式
  716. //获取服务器时间的,在日历上记录打卡
  717. $.post('getPunchByUserId.ht',{},function(res){
  718. var json =JSON.parse(res);
  719. var html="";
  720. current=eval(json.message);//将json数组串转成json数组对象
  721. for (var i=0;i<current.length;i++){
  722. //截取日期時間
  723. var fPunchTime=current[i].fPunchTime.split(" ")[0];
  724. //状态
  725. var fPunchstate=current[i].fPunchState;
  726. if (fPunchstate==2){
  727. //状态为2代表没迟到 ,顯示綠色
  728. t.find('td[abbr="' + fPunchTime + '"]').children("i:eq(0)").addClass('shang1');
  729. }else if (fPunchstate==0){
  730. //状态为0代表迟到,顯示紅色
  731. t.find('td[abbr="' + fPunchTime + '"]').children("i:eq(0)").addClass('shang2');
  732. }else if (fPunchstate==1){
  733. //状态为1代表早退,顯示紅色
  734. t.find('td[abbr="' + fPunchTime + '"]').children("u:eq(0)").addClass('xia2');
  735. }else if (fPunchstate==3){
  736. //状态为1代表沒早退,顯示綠色
  737. t.find('td[abbr="' + fPunchTime + '"]').children("u:eq(0)").addClass('xia1');
  738. }
  739. }
  740. });
  741. var saIndex = 6 - opts.firstDay;
  742. var suIndex = saIndex + 1;
  743. if (saIndex >= 7)
  744. saIndex -= 7;
  745. if (suIndex >= 7)
  746. suIndex -= 7;
  747. t.find('tr').find('td:eq(' + saIndex + ')').addClass('calendar-saturday');
  748. t.find('tr').find('td:eq(' + suIndex + ')').addClass('calendar-sunday');
  749. t.find('td').hover(
  750. function () {
  751. $(this).addClass('calendar-hover');
  752. },
  753. function () {
  754. $(this).removeClass('calendar-hover');
  755. }).click(function () {
  756. t.find('.calendar-selected').removeClass('calendar-selected').css('backgroundColor', '');
  757. $(this).addClass('calendar-selected').css('backgroundColor', 'rgb(129, 208, 242)');
  758. //获取到当前日期
  759. var parts = $(this).attr('abbr').split('-');
  760. //动态添加div给予赋值
  761. window.parent.$("#iframe").append('<div class="div_val">'+parts+'</div>');
  762. //获取div的值
  763. var div_val=window.parent.$("#iframe").find(".div_val").text();
  764. //替换 所有,逗号
  765. var rep= div_val.replace(/\,/g,'-');
  766. //判断div是否存在 存在就移除掉
  767. if(window.parent.$("#iframe").find(".div_val").hasClass("div_val")){
  768. window.parent.$("#iframe").find(".div_val").remove();
  769. }
  770. //把值赋给文本框
  771. window.parent.$("#iframe").find("#J-xl").val( );
  772. //点击文本框隐藏
  773. //if($(this).onclick=true){
  774. // window.parent.$("#iframepage").fadeOut();
  775. //}
  776. opts.current = new Date(parts[0], parseInt(parts[1]) - 1, parts[2]);
  777. // alert(parts[0]); 输出是年 ;
  778. opts.onSelect.call(target, opts.current, this);
  779. if (opts.month != parts[1]) {
  780. opts.year = parts[0];
  781. opts.month = parts[1];
  782. show(target);
  783. }
  784. });
  785. opts.onChange.call(target, opts.year, opts.month);
  786. //初始化页面完毕后选择工作日和休息日
  787. checkHo_day(opts.year, opts.month);
  788. }
  789. //easyui-fullCalendar calendar 获取这class 高度宽度
  790. function calculatePos(target, currentTarget) {
  791. var w = $(this).width(),
  792. h = $(this).height();
  793. var x = getElementLeft(currentTarget) + currentTarget.offsetWidth,
  794. y = getElementTop(currentTarget);
  795. if (x + $(target).width() > w) {
  796. x = x - $(target).width() - currentTarget.offsetWidth - 9;
  797. }
  798. if (y + $(target).height() > h) {
  799. y = h - $(target).height() - 28;
  800. }
  801. return {
  802. left : x,
  803. top : y
  804. };
  805. }
  806. function getElementLeft(element) {
  807. var actualLeft = element.offsetLeft;
  808. var current = element.offsetParent;
  809. while (current !== null) {
  810. actualLeft += current.offsetLeft;
  811. current = current.offsetParent;
  812. }
  813. return actualLeft;
  814. }
  815. function getElementTop(element) {
  816. var actualTop = element.offsetTop;
  817. var current = element.offsetParent;
  818. while (current !== null) {
  819. actualTop += current.offsetTop;
  820. current = current.offsetParent;
  821. }
  822. return actualTop;
  823. }
  824. $.fn.fullCalendar = function (options, param) {
  825. if (typeof options == 'string') {
  826. return $.fn.fullCalendar.methods[options](this, param);
  827. }
  828. options = options || {};
  829. return this.each(function () {
  830. var state = $.data(this, 'fullCalendar');
  831. if (state) {
  832. $.extend(state.options, options);
  833. } else {
  834. state = $.data(this, 'fullCalendar', {
  835. options : $.extend({}, $.fn.fullCalendar.defaults, $.fn.calendar.defaults, $.fn.fullCalendar.parseOptions(this), options)
  836. });
  837. init(this);
  838. }
  839. if (state.options.border == false) {
  840. $(this).addClass('calendar-noborder');
  841. }
  842. setSize(this);
  843. show(this);
  844. $(this).find('div.calendar-menu').hide(); // hide the calendar menu
  845. });
  846. };
  847. $.fn.fullCalendar.methods = {
  848. options : function (jq) {
  849. return $.data(jq[0], 'fullCalendar').options;
  850. },
  851. resize : function (jq) {
  852. return jq.each(function () {
  853. setSize(this);
  854. });
  855. },
  856. moveTo : function (jq, date) {
  857. return jq.each(function () {
  858. $(this).fullCalendar({
  859. year : date.getFullYear(),
  860. month : date.getMonth() + 1,
  861. current : date
  862. });
  863. });
  864. }
  865. };
  866. $.fn.fullCalendar.parseOptions = function (target) {
  867. var t = $(target);
  868. return $.extend({}, $.parser.parseOptions(target, [
  869. 'width', 'height', {
  870. firstDay : 'number',
  871. fit : 'boolean',
  872. border : 'boolean'
  873. }
  874. ]));
  875. };
  876. $.fn.fullCalendar.defaults = {
  877. width : 180,
  878. height : 180,
  879. fit : false,
  880. border : true,
  881. firstDay : 0,
  882. weeks : ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六'],
  883. months : ['一', '二', '三', '四', '五', '六', '七', '八', '九', '十', '十一', '十二'],
  884. year : new Date().getFullYear(),//完整的年份
  885. month : new Date().getMonth() + 1, //当前月份
  886. current : new Date(),//时间
  887. solarTerms : true, //显示二十四节气
  888. lunarDay : true, //显示农历
  889. onSelect : function (date, target) {},
  890. onChange : function (year, month) {}
  891. };
  892. //增加样式
  893. $('head').append('<style>.fullcalendar-day {border-left: 1px solid #eee;border-top: 1px solid #eee;} '
  894. + '.calendar-hover{background:rgb(129, 208, 242);}.fullcalendar-body th{padding: 5px;height:20px;}'
  895. + '.fullcalendar-detail{border-radius:5px;position: absolute; z-index: 10; background-color: #2B91D5; display: none; opacity: 0.8; padding: 5px; text-align: right;filter: Alpha(opacity=80);width:150px;}'
  896. + '.fullcalendar-detail div{background:#f8f8f8;margin-top: 3px;font-size: 12px;padding: 2px;}'
  897. + '.fullcalendar-detail .lunarFestival{color: red;}.fullcalendar-detail .solarFestival{color: #000;}/*.fullcalendar-body td.festival{background:url("");background-repeat: no-repeat;background-position: top right;}*/</style>');
  898. $.parser.plugins.push('fullCalendar');
  899. })(jQuery);
  900. //新增日程方法
  901. function add(){
  902. var date=$(".calendar-selected").attr('abbr');
  903. window.parent.add(date);
  904. }
  905. //选择切换方法
  906. function onSelect(td){
  907. var date=$(td).attr("abbr");
  908. $.post('getMyScheduleList.ht',{f_date:date},function(res){
  909. var json =JSON.parse(res);
  910. var json_arr=eval(json.message);
  911. var html="";
  912. for(var i=0;i<json_arr.length;i++){
  913. if(i%2==0){
  914. html+='<div class="list-group-item" style="height:37px;"><a id="'+json_arr[i].id+'" onclick="getMySchedule('+json_arr[i].id+')" class="text-ellipsis" style="float: left; display: block; width: 94%;" title="'+json_arr[i].f_myschedulename+'"> <span class="badge bg-success" style="float:right;">'+json_arr[i].f_time.substr(0,json_arr[i].f_time.length-3)+'</span> '+json_arr[i].f_myschedulename.substr(0,15)+
  915. ' </a><a onclick="del('+json_arr[i].id+')" style="float: right; color: #fff; width: 18px; height: 18px; background: #f95b5b; border-radius: 50%; text-align: center; font-size: 10px; line-height: 18px;">X</a></div>';
  916. }else{
  917. html+='<div class="list-group-item" style="height:37px;"><a id="'+json_arr[i].id+'" onclick="getMySchedule('+json_arr[i].id+')" class="text-ellipsis" style="float: left; display: block; width: 94%;" title="'+json_arr[i].f_myschedulename+'"> <span class="badge bg-success" style="float:right;">'+json_arr[i].f_time.substr(0,json_arr[i].f_time.length-3)+'</span> '+json_arr[i].f_myschedulename.substr(0,15)+
  918. ' </a><a onclick="del('+json_arr[i].id+')" style="float: right; color: #fff; width: 18px; height: 18px; background: #f95b5b; border-radius: 50%; text-align: center; font-size: 10px; line-height: 18px;">X</a></div>';
  919. }
  920. }
  921. parent.clear();
  922. parent.addMySchedule(html);
  923. });
  924. }