rehabilitation_management.js 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306
  1. !function(){
  2. var httpData=GetRequest();
  3. var currentGMT=new Date();//当前时间GMT
  4. new Vue({
  5. el:"#app",
  6. data:{
  7. ynow: currentGMT.getFullYear(),//年份
  8. mnow: currentGMT.getMonth(),//月份(比实际少一个月---0开始至11)
  9. dnow: currentGMT.getDate(),//当前日
  10. currentDay:null,//带中文格式的当前年月
  11. currentDayForEn:null,//不带中文格式年月日2018/10/01如果写成/的话 转换成时间戳会变成北京时间8点
  12. calendarData:[],//日历数据
  13. timeAxisData:[],//时间轴数据
  14. __Data:[],//当前的年月(日历)
  15. __xData:[],//当前的年月(时间轴)
  16. status:null,//任务状态(0未完成,1已完成,2已预约)
  17. searchTask:null,//快速查找任务:(1、我的任务,2、健康教育,3、健康指导,4、随访,5、复诊)
  18. planId: httpData['planId'],
  19. taskArr:[
  20. {code:1,name:'我的任务'},
  21. {code:2,name:'健康教育'},
  22. {code:3,name:'健康指导'},
  23. {code:4,name:'随访'},
  24. {code:5,name:'复诊'},
  25. ],
  26. statusArr:[
  27. {code:0,name:'未完成'},
  28. {code:1,name:'已完成'},
  29. {code:2,name:'已预约'},
  30. ],
  31. curTask:'',//快速查找是否点击了搜索按钮
  32. curTaskName:'',//快速查找是否点击了搜索按钮
  33. tabStatus:null,
  34. },
  35. mounted:function(){
  36. if(!this.planId){
  37. layer.msg('未传入计划id(planId)',{icon:2})
  38. }else{
  39. this.tabStatus=1;
  40. }
  41. },
  42. methods:{
  43. refreshPage:function(){
  44. if(!this.planId){
  45. layer.msg('未传入计划id(planId)',{icon:2})
  46. return ;
  47. }
  48. this.goToLoadData(true);
  49. },
  50. viewDetail:function(planids,status){
  51. var vm=this;
  52. if(!planids){
  53. layer.msg('无服务项',{icon:5})
  54. return ;
  55. }
  56. if(status==1){
  57. top.layer.open({
  58. type: 2,
  59. area: ['800px', '650px'],
  60. shade: 0.5,
  61. title: '完成项目确认',
  62. fixed: true, //不固定
  63. maxmin: true,
  64. closeBtn:1,
  65. shift: 5,
  66. shadeClose: false, //点击遮罩关闭层
  67. content: '../../rehabilitation/html/guide_the_message.html?planid='+planids
  68. });
  69. return ;
  70. }
  71. // planids='402803f6657f195301657f4c4ce70000';
  72. layer.open({
  73. type: 2,
  74. area: ['800px', '650px'],
  75. shade: 0.5,
  76. title: '服务项目内容',
  77. fixed: true, //不固定
  78. maxmin: true,
  79. closeBtn:1,
  80. shift: 5,
  81. shadeClose: false, //点击遮罩关闭层
  82. content: '../../rehabilitation/html/service_item_content.html?planids='+planids,
  83. end:function(){
  84. vm.goToLoadData(true);
  85. }
  86. });
  87. },
  88. changeStatus:function(val){
  89. this.status=this.status==val?null:val;
  90. },
  91. changeTask:function(val){
  92. this.searchTask=this.searchTask==val?null:val;
  93. },
  94. monDetail:function(){
  95. this.currentDay = this.ynow + '年'+ (this.mnow + 1) +'月';
  96. this.currentDayForEn=this.ynow+'/'+(this.mnow>=9?(this.mnow+1):"0"+(this.mnow+1))+'/'+(this.dnow>=9?this.dnow:"0"+this.dnow)
  97. },
  98. is_leap:function(year) { //判断是否为闰年
  99. return (year%100==0?res=(year%400==0?1:0):res=(year%4==0?1:0));
  100. },
  101. preMonth:function(){ //上一个月
  102. if(this.mnow<=0){
  103. this.mnow=11;
  104. this.ynow=this.ynow-1;
  105. }else{
  106. this.mnow--;
  107. }
  108. this.monDetail();
  109. this.goToLoadData(true);
  110. },
  111. getPreMouth:function(){
  112. var pMnow,pYnow;
  113. if(this.mnow<=0){
  114. pMnow=11;
  115. pYnow=this.ynow-1;
  116. }else{
  117. pMnow=this.mnow-1;
  118. pYnow=this.ynow;
  119. }
  120. var m_days=new Array(31,(28+this.is_leap(pYnow)),31,30,31,30,31,31,30,31,30,31); //每个月的天数
  121. return {
  122. days:m_days[pMnow],
  123. date:pYnow+'-'+(++pMnow>=10?pMnow:"0"+pMnow)
  124. }
  125. },
  126. nextMonth:function(){ //下一个月
  127. if(this.mnow>=11){
  128. this.mnow=0;
  129. this.ynow=this.ynow+1;
  130. }else{
  131. this.mnow++;
  132. }
  133. this.monDetail();
  134. this.goToLoadData(true);
  135. },
  136. getNextMouth:function(){
  137. var nMnow,nYnow;
  138. if(this.mnow>=11){
  139. nMnow=0;
  140. nYnow=this.ynow+1;
  141. }else{
  142. nMnow=this.mnow+1;
  143. nYnow=this.ynow;
  144. }
  145. var m_days=new Array(31,(28+this.is_leap(nYnow)),31,30,31,01,31,31,30,31,30,31); //每个月的天数
  146. return {
  147. days:m_days[nMnow],
  148. date:nYnow+'-'+(++nMnow>=10?nMnow:"0"+nMnow)
  149. }
  150. },
  151. goToLoadData:function(flag){//flag是否更新数据
  152. this.tabStatus==1 && (!this.calendarData.length || flag) && this.calendar();
  153. this.tabStatus==2 && (!this.timeAxisData.length || flag) && this.timeAxis();
  154. },
  155. calendar:function(){
  156. var nlstr = new Date(this.ynow,this.mnow,1); //当月第一天
  157. var firstday = nlstr.getDay()-1;//第一天星期几,默认是周日 我们改成周一
  158. firstday=firstday==-1?6:firstday;//如果是-1,说明当月的第一天是周日
  159. var m_days=new Array(31,(28+this.is_leap(this.ynow)),31,30,31,30,31,31,30,31,30,31); //每个月的天数
  160. var tr_str=Math.ceil((m_days[this.mnow] + firstday)/7); //当前月天数+第一天是星期几的数值 获得 表格行数
  161. var c_days=m_days[this.mnow];//当前月份的天数
  162. var p_arr=this.getPreMouth();
  163. var n_arr=this.getNextMouth();
  164. var i,k,idx,date_str;
  165. var dataArr=[];//天数/年月
  166. for(i=0;i<tr_str;i++) { //表格的行
  167. for(k=0;k<7;k++) { //表格每行的单元格
  168. idx=i*7+k; //单元格自然序列号
  169. date_str=idx-firstday+1; //计算日期
  170. var __ym;
  171. if(date_str<=0){//过滤无效日期(小于等于零的、大于月总天数的)
  172. date_str=date_str+p_arr['days'];//当前日期+上个月的天数就是上个月的日期
  173. __ym=p_arr['date'];
  174. }else if(date_str>c_days){
  175. date_str=date_str-c_days;//下个月的日期就是这个月的天数-当月的天数
  176. __ym=n_arr['date'];
  177. }else{
  178. __ym=this.ynow+'-'+(this.mnow>=9?"":"0")+(this.mnow+1);
  179. }
  180. dataArr.push({
  181. day:date_str,
  182. date:__ym
  183. });
  184. }
  185. }
  186. this.__Data=dataArr;
  187. this.monDetail();
  188. this.calenderPlanDetail();
  189. },
  190. // 日历请求
  191. calenderPlanDetail:function(){
  192. var vm=this;
  193. var __days=vm.__Data;
  194. var lastDay=(__days.concat()).pop().day;
  195. lastDay=lastDay>9?lastDay:'0'+lastDay;
  196. var params={
  197. executeStartTime:__days[0].date+'-'+__days[0].day+' 00:00:00',//日历开始时间(格式:yyyy-MM-dd HH:mm:ss)
  198. executeEndTime:(__days.concat()).pop().date+'-'+lastDay+' 23:59:59',//日历结束时间(格式:yyyy-MM-dd HH:mm:ss)
  199. planId:vm.planId,//计划id
  200. searchTask:vm.searchTask,//快速查找任务:(1、我的任务,2、健康教育,3、健康指导,4、随访)
  201. status:vm.status,//任务状态(0未完成,1已完成,2已预约)
  202. }
  203. rehaAPI.calendarPlanDetail(params).then(function(res){
  204. vm.curTask=vm.searchTask;
  205. vm.curTaskName=vm.taskArr[vm.searchTask].name;
  206. vm.calendarData=[];
  207. if(res.status==200){
  208. var data=res.data
  209. for(var i in __days){
  210. var _key=__days[i].date+'-'+(__days[i].day>9?__days[i].day:'0'+__days[i].day);
  211. var item={
  212. noService:true,
  213. day:__days[i].day
  214. };
  215. for(var j in data){
  216. if(_key==j){
  217. item=data[j];
  218. item.day=__days[i].day;
  219. var finishFlag=false;
  220. var sFlag=false;
  221. var fFlag=false;
  222. if(item.specialist){
  223. if(item.specialist.all==item.specialist.finish){
  224. sFlag=true;
  225. }
  226. }else{
  227. sFlag = true;
  228. }
  229. if(item.family){
  230. if(item.family.all==item.family.finish){
  231. fFlag = true;
  232. }
  233. }else{
  234. fFlag = true;
  235. }
  236. finishFlag = sFlag && fFlag;
  237. item.finishFlag=finishFlag;
  238. data.length && data.splice(j,1);
  239. break;
  240. }
  241. }
  242. vm.calendarData.push(item);
  243. }
  244. }
  245. })
  246. },
  247. // 时间轴请求
  248. timeAxis:function(){
  249. var m_days=new Array(31,(28+this.is_leap(this.ynow)),31,30,31,30,31,31,30,31,30,31); //每个月的天数
  250. var c_days=m_days[this.mnow];//当前月份的天数
  251. var __ym=this.ynow+'-'+(this.mnow>=9?"":"0")+(this.mnow+1);
  252. var dataArr=[];//天数/年月
  253. for(;c_days>0;c_days--){
  254. dataArr.push({
  255. day:c_days,
  256. date:__ym
  257. });
  258. }
  259. this.__xData=dataArr;
  260. this.monDetail();
  261. this.calendarPlanDetailList();
  262. },
  263. // 时间轴请求
  264. calendarPlanDetailList:function(){
  265. var vm=this;
  266. var __days=vm.__xData;
  267. var lastDay=(__days.concat()).pop().day;
  268. lastDay=lastDay>9?lastDay:'0'+lastDay;
  269. var params={
  270. executeEndTime:__days[0].date+'-'+__days[0].day+' 00:00:00',//日历开始时间(格式:yyyy-MM-dd HH:mm:ss)
  271. executeStartTime:(__days.concat()).pop().date+'-'+lastDay+' 23:59:59',//日历结束时间(格式:yyyy-MM-dd HH:mm:ss)
  272. planId:vm.planId,//计划id
  273. searchTask:vm.searchTask,//快速查找任务:(1、我的任务,2、随访,3、复诊,4、健康教育)
  274. status:vm.status,//任务状态(0未完成,1已完成,2已预约)
  275. }
  276. rehaAPI.calendarPlanDetailList(params).then(function(res){
  277. if(res.status==200){
  278. var _currentTimeStamp=+new Date(vm.currentDayForEn);
  279. vm.timeAxisData=_.map(res.data||{},function(o){
  280. var _time=o.executeTime.split(' ');
  281. var thatTime=+new Date(_time[0]);
  282. var future=_currentTimeStamp>thatTime?0:(_currentTimeStamp==thatTime?1:2);
  283. (o.status==0 && _currentTimeStamp>thatTime) && (future=-1)
  284. console.log(future)
  285. var _html=o.status==2?'预':(future==-1?'逾':'');
  286. _html=future==1?'今':_html;
  287. if(_html=='预') future=3;
  288. o.html=_html
  289. o.date=_time[0];
  290. o.time=_time[1];
  291. o.future=future;
  292. return o;
  293. })||[];
  294. }
  295. console.log(vm.timeAxisData)
  296. })
  297. },
  298. },
  299. watch:{
  300. tabStatus:function(){
  301. this.goToLoadData();
  302. }
  303. }
  304. })
  305. }();