rehabilitation_management.html 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>康复管理</title>
  6. <link rel="shortcut icon" href="../../favicon.ico">
  7. <link rel="stylesheet" type="text/css" href="../../../css/bootstrap.min.css"/>
  8. <link rel="stylesheet" type="text/css" href="../../../css/style.min.css"/>
  9. <link rel="stylesheet" type="text/css" href="../../../css/cross.css"/>
  10. <link rel="stylesheet" type="text/css" href="../css/date.css" />
  11. <style type="text/css">
  12. .flex-box{display: -webkit-box; /* OLD - iOS 6-, Safari 3.1-6 */ /* OLD - Firefox 19- (buggy but mostly works) */
  13. display: -ms-flexbox; /* TWEENER - IE 10 */ /* NEW - Chrome */
  14. display: flex; /* NEW, Spec - Opera 12.1, Firefox 20+ */
  15. -webkit-box-pack: center;
  16. -ms-flex-pack: center;
  17. justify-content: center;
  18. -webkit-box-align: center;
  19. -ms-flex-align: center;
  20. align-items: center;
  21. -ms-flex-wrap: wrap;
  22. flex-wrap: wrap;
  23. }
  24. .flex-box-item{-webkit-box-flex: 1; /* OLD - iOS 6-, Safari 3.1-6 */
  25. -moz-box-flex: 1; /* OLD - Firefox 19- */
  26. -webkit-flex: 1; /* Chrome */
  27. -ms-flex: 1; /* IE 10 */
  28. width: 50%; /* For old syntax, otherwise collapses. */
  29. flex: 1; /* NEW, Spec - Opera 12.1, Firefox 20+ */
  30. position: relative;}
  31. [flex-grow="2"]{-webkit-box-flex: 2;-ms-flex-positive: 2;flex-grow: 2;}
  32. [flex-grow="5"]{-webkit-box-flex: 5;-ms-flex-positive: 5;flex-grow: 5;}
  33. body,html,.c-container{height: 100%;}
  34. .rehabilition{height: 100%;padding-top: 49px;max-width: 1620px;margin: 0 auto;}
  35. .nav-content-right{height: 100%;overflow: auto;}
  36. .search-left{border-right: solid 1px #d7dce6;background-color: #f5f5f5;height: 100%;}
  37. .mw400{max-width: 400px;}
  38. .search-condition{padding: 20px 10px;border-bottom: solid 1px #d7dce6;}
  39. .search-condition p{font-size: 14px;margin-bottom: 15px;}
  40. .task-list{padding-left: 10px;overflow: hidden;}
  41. .task-list li{width: 90px;cursor: pointer;text-align: center;display: block;float: left;border-radius: 14px;font-size: 14px;margin-left: 20px;margin-bottom: 20px;color: #333333;border: solid 1px #d7dce6;padding: 3px;}
  42. .task-list li.active{background-color: #12b7f5;color: #fff;}
  43. .btn-search{background-color: #12b7f5;color: #fff;border-radius: 0;width: 120px;margin-top: 30px;}
  44. .btn-search:hover,.btn-search:focus,.btn-search:active,.btn-search:hover:active{background-color: #00ADEE;color: #fff;}
  45. /*日历*/
  46. .calendar-content{margin: 0 auto;}
  47. /*图例注释*/
  48. .calendar-descript{padding: 15px 20px;background-color: #fff;}
  49. .calendar-descript span{vertical-align: middle;}
  50. .icon{width: 12px;height: 12px;vertical-align: middle;background-size: 100% 100%;background-repeat: no-repeat;display: inline-block;}
  51. .icon-blue{background-color: #12b7f5;border-radius: 2px;}
  52. .icon-green{background-color: #2dbe55;border-radius: 2px;}
  53. .icon-flag{background-image: url(../images/woderenwu_icon.png);}
  54. .icon-shuaxin{background-image: url(../images/icon/shuaxin.png);}
  55. .icon-shuaxin:hover{background-image: url(../images/icon/shuaxin1.png);}
  56. .icon-back{background-image: url(../images/icon/fanhui_icon.png);}
  57. .icon-back:hover{background-image: url(../images/icon/fanhui02_icon.png);}
  58. .icon-check{background-image: url(../images/wancheng_icon.png);}
  59. .icon-prev{background-image: url(../images/icon/houtui_icon.png);}
  60. .icon-next{background-image: url(../images/icon/qianjing_icon.png);}
  61. .icon-rili{background-image: url(../images/icon/rilibiao02_icon.png);}
  62. .rili:hover .icon-rili,.active .icon-rili{background-image: url(../images/icon/rilibiao_icon.png);}
  63. .icon-liebiao{background-image: url(../images/icon/shijianzhou_icon.png);}
  64. .shijianzhou:hover .icon-liebiao,.active .icon-liebiao{background-image: url(../images/icon/shijianzhou02_icon.png);}
  65. .icon-20{width: 20px;height: 20px;}
  66. .icon-16{width: 16px;height: 16px;}
  67. /*周期*/
  68. .calendar-week{background-color: #ebebf5;border: solid 1px #d7dce6;padding: 11px;}
  69. /*日期*/
  70. .calendar-days>.flex-box{border-bottom: 1px solid #d7dce6;}
  71. .calendar-day{height: 135px;border-left: 1px solid #d7dce6;cursor: pointer;position: relative;padding: 5px;width: 14.28571428%;border-bottom: 1px solid #d7dce6;}
  72. .calendar-days .calendar-day:first-child{border-left-width: 0;}
  73. .calendar-day:hover{-webkit-box-shadow: 0 0 0 1px #12b7f5 inset;box-shadow: 0 0 0 1px #12b7f5 inset;}
  74. .calendar-day.current-day{background-color: #ddf6fe;}
  75. .no-server{text-align: center;top: 50%;position: absolute;left: 0;right: 0;color: #c8c8c8;font-size: 18px;}
  76. /*彩带*/
  77. .coloured-ribbon{font-size: 12px;width: 22px;text-align: center;height: 40px;display: inline-block;padding-top: 8px;line-height: 1;color: #fff;}
  78. .coloured-box{top: 0;position: absolute;right: 5px;}
  79. .coloured-ribbon-blue{background: url(../images/biaoqian-lanse_img.png) center center / 100% 100% no-repeat;}
  80. .coloured-ribbon-green{background: url(../images/biaoqian-lvse_img.png) center center / 100% 100% no-repeat;margin-left: 5px;}
  81. .task-icon{position: absolute;right: 63px;top: 10px;min-height: 20px;}
  82. .task-icon .icon-check{position: absolute;right: -3px;bottom: 0;width: 15px;height: 15px;}
  83. .day-number{font-size: 28px;color: #999999;margin-bottom: 0;line-height: 1;}
  84. /*进度条*/
  85. .progress-box{position: absolute;bottom: 0;left: 0;right: 0;padding: 5px;}
  86. .progress-box .progress{margin-bottom: 9px;background-color: #d7dce6;border-radius: 10px;position: relative;}
  87. .progress-box .progress > span{position: absolute;left: 0;right: 0;text-align: center;color: #333333;top: 2px;}
  88. .progress-box .progress-bar{background-color: #12b7f5;}
  89. .progress-box .progress-bar-success{background-color: #2dbe55;}
  90. /*页头*/
  91. .page-title{position: fixed;top: 0;left: 0;right: 0;padding: 9px;border-bottom: 1px solid #d7dce6;z-index: 5;max-width: 1620px;margin: 0 auto;background-color: #fff}
  92. .page-title-name{padding-right: 15px;font-size: 14px;border-right: 1px solid #d7dce6;display: inline-block;margin-right: 10px;}
  93. .page-title span{vertical-align: middle;}
  94. .mr10{margin-right: 10px;}
  95. .page-title .icon{cursor: pointer;}
  96. .currentDay{font-size: 16px;margin: 0 25px;vertical-align: middle;width: 100px;text-align: justify;text-align-last: justify;display: inline-block;}
  97. .switch-list{border: solid 1px #12b7f5;border-radius: 6px;overflow: hidden;}
  98. .switch-list .icon{position: relative;top: 3px;}
  99. .rili,.shijianzhou{width: 40px;height: 28px;display: inline-block;float: left;background-color: #fff;}
  100. .rili.active,.shijianzhou.active,.rili:hover,.shijianzhou:hover{background-color: #12b7f5;border-radius: 5px;}
  101. /*列表展示*/
  102. .time-axis td{border: none !important;color: #999;}
  103. .time-axis th{background-color: #f5f5fa;border-bottom: solid 1px #d7dce6;}
  104. .time-axis td p{color: #999;}
  105. .ellipsis{white-space: nowrap;overflow: hidden;text-overflow: ellipsis;}
  106. .time{position: relative;}
  107. .time-box{position: relative;padding: 8px 50px 8px 8px!important;}
  108. .cur-status{position: absolute;z-index: 3;right: 5px;top: 50%;padding: 8px;line-height: 1;margin-top: -12.5px;border-radius: 100%;color: #fff;}
  109. .cur-status:empty{margin-top: -8px;right: 12.5px;background-color: #d7dce6;}
  110. [is-future="1"]{background-color: #dff5fc;}
  111. .time-axis tr:hover{background-color: #f5f5fa;}
  112. .time-axis tr:hover p{color: #333333;}
  113. [is-future="1"] .cur-status,[is-future="2"] .cur-status{background-color: #12b7f5;}
  114. [is-future="3"] .cur-status{background-color: #5cb85c;}
  115. .time-box:after{content: '';position: absolute;right: 0;z-index: 2;right: 19px;height: 100%;width: 1px;background-color: #d7dce6;top: 50%;}
  116. .time-axis tr:nth-last-of-type(1) .time-box:after{display: none;}
  117. .view-task{text-align: center;cursor: pointer;}
  118. [v-cloak]{display: none;}
  119. .visibility-hide{visibility: hidden;}
  120. </style>
  121. </head>
  122. <body>
  123. <div class="c-container" id="app" v-cloak>
  124. <div class="page-title flex-box">
  125. <div class="flex-box-item mw400" flex-grow="2">
  126. <span class="page-title-name">康复计划</span><i class="icon icon-back icon-16 mr10"></i><i class="icon icon-shuaxin icon-16"></i>
  127. </div>
  128. <div class="flex-box-item text-center" flex-grow="5">
  129. <div class="pull-right switch-list">
  130. <span class="rili" :class="{active:(tabStatus==1)}" @click="tabStatus=1"><i class="icon icon-rili icon-20"></i></span>
  131. <span class="shijianzhou" :class="{active:(tabStatus==2)}" @click="tabStatus=2"><i class="icon icon-liebiao icon-20"></i></span>
  132. </div>
  133. <span style="position: relative;top: 5px;">
  134. <i class="icon icon-prev icon-20" @click="preMonth"></i>
  135. <span class="currentDay">{{currentDay}}</span>
  136. <i class="icon icon-next icon-20" @click="nextMonth"></i></span>
  137. </div>
  138. </div>
  139. <div class="flex-box rehabilition">
  140. <div class="flex-box-item search-left mw400" flex-grow="2">
  141. <div class="search-condition">
  142. <p>快速找任务</p>
  143. <ul class="task-list">
  144. <li :class="{'active':(searchTask==task.code)}" v-for="task in taskArr" @click="changeTask(task.code)">{{task.name}}</li>
  145. </ul>
  146. <p>任务状态</p>
  147. <ul class="task-list">
  148. <li :class="{'active':(status==sts.code)}" v-for="sts in statusArr" @click="changeStatus(sts.code)">{{sts.name}}</li>
  149. </ul>
  150. </div>
  151. <div class="text-center">
  152. <button class="btn btn-search" @click="goToLoadData">确认</button>
  153. </div>
  154. </div>
  155. <div class="flex-box-item nav-content-right" flex-grow="5">
  156. <div class="calendar-content" v-show="tabStatus==1">
  157. <div class="calendar-descript">
  158. <span>图例注释: </span><i class="icon icon-blue"></i> <span>专科团队</span>&emsp;<i class="icon icon-green"></i> <span>家医团队</span>&emsp; <i class="icon icon-flag"></i> <span>我的任务</span>
  159. </div>
  160. <div class="calendar-week">
  161. <div class="flex-box text-center">
  162. <div class="flex-box-item">
  163. 周一
  164. </div>
  165. <div class="flex-box-item">
  166. 周二
  167. </div>
  168. <div class="flex-box-item">
  169. 周三
  170. </div>
  171. <div class="flex-box-item">
  172. 周四
  173. </div>
  174. <div class="flex-box-item">
  175. 周五
  176. </div>
  177. <div class="flex-box-item">
  178. 周六
  179. </div>
  180. <div class="flex-box-item">
  181. 周日
  182. </div>
  183. </div>
  184. </div>
  185. <div class="calendar-days">
  186. <div class="flex-box">
  187. <div class="calendar-day" v-for="item in calendarData" @click="viewDetail(item.planDetailIds)">
  188. <span class="day-number">{{item.day}}</span>
  189. <div class="task-icon">
  190. <i v-if="item.myTaskFlag" class="icon icon-flag icon-20"></i>
  191. <i v-if="item.finishFlag" class="icon icon-check"></i>
  192. </div>
  193. <div class="coloured-box">
  194. <span v-if="item.specialist" class="coloured-ribbon coloured-ribbon-blue">专<br />科</span>
  195. <span v-if="item.family" class="coloured-ribbon coloured-ribbon-green">家<br />医</span>
  196. </div>
  197. <div class="progress-box">
  198. <div class="progress" :style="{opacity:item.specialist?'1':'0'}">
  199. <span>{{(item.specialist && item.specialist.finish)+'/'+(item.specialist && item.specialist.all)}}</span>
  200. <div class="progress-bar" role="progressbar" aria-valuenow="0" aria-valuemin="0" aria-valuemax="100" :style="{width: (item.specialist?(item.specialist.finish/item.specialist.all):0)*100+'%'}"></div>
  201. </div>
  202. <div class="progress" :style="{opacity:item.family?'1':'0'}">
  203. <span>{{(item.family && item.family.finish)+'/'+(item.family && item.family.all)}}</span>
  204. <div class="progress-bar progress-bar-success" role="progressbar" aria-valuenow="2" aria-valuemin="0" aria-valuemax="100" :style="{width: (item.family?(item.family.finish/item.family.all):0)*100+'%'}"></div>
  205. </div>
  206. <p v-if="!item.noService" class="mb0 f12" :class="{'visibility-hide':!curTask}" style="line-height: 1;">{{curTask==1?'我的任务':(curTask==2?'随访':(curTask==3?'复诊':(curTask==4?'健康教育':'&emsp;')))}}</p>
  207. </div>
  208. <p v-if="item.noService" class="no-server">无服务项</p>
  209. </div>
  210. </div>
  211. </div>
  212. </div>
  213. <div class="time-axis" v-show="tabStatus==2">
  214. <table class="table">
  215. <tr>
  216. <th style="padding-right: 50px;text-align: right;">时间</th>
  217. <th class="text-center">项目</th>
  218. <th>执行人员</th>
  219. <th>执行地点</th>
  220. <th>相关记录</th>
  221. <th class="text-center">状态</th>
  222. </tr>
  223. <tr v-for="item in timeAxisData" :is-future="item.future">
  224. <td class="time text-right time-box">
  225. <p class="mb5">{{item.date}}</p>
  226. <p class="mb0">{{item.time}}</p>
  227. <span class="cur-status">{{item.html}}</span>
  228. </td>
  229. <td class="project-name">
  230. <p class="mb5">{{item.title}}</p>
  231. <p class="ellipsis mb0">{{item.content}}</p>
  232. </td>
  233. <td class="executor">{{item.doctor_name}}</td>
  234. <td class="place-of-execution">{{item.hospital_name}}</td>
  235. <td class="view-task" @click="viewDetail(item.id)">查看</td>
  236. <td class="task-status">{{item.status==0?'未完成':(item.status==1?'已完成':'已预约')}}</td>
  237. </tr>
  238. <tr v-if="!timeAxisData.length">
  239. <td colspan="6" class="f16 ptb10 text-center">暂无数据</td>
  240. </tr>
  241. </div>
  242. </div>
  243. </div>
  244. </div>
  245. </div>
  246. <script type="text/javascript" src="../../../js/vue.js"></script>
  247. <script type="text/javascript" src="../../../js/jquery-2.2.4.js"></script>
  248. <script type="text/javascript" src="../../../api/http-request.js"></script>
  249. <script type="text/javascript" src="../../../plugins/layer/layer.min.js" ></script>
  250. <script type="text/javascript" src="../../../api/rehabilitation-api.js"></script>
  251. <script type="text/javascript" src="../../../js/underscore.js"></script>
  252. <script src="../../../js/util.js" type="text/javascript" charset="utf-8"></script>
  253. <script type="text/javascript">
  254. !function(){
  255. var httpData=GetRequest();
  256. var currentGMT=new Date();//当前时间GMT
  257. new Vue({
  258. el:"#app",
  259. data:{
  260. ynow: currentGMT.getFullYear(),//年份
  261. mnow: currentGMT.getMonth(),//月份(比实际少一个月---0开始至11)
  262. dnow: currentGMT.getDate(),//当前日
  263. currentDay:null,//带中文格式的当前年月
  264. currentDayForEn:null,//不带中文格式年月日2018/10/01如果写成/的话 转换成时间戳会变成北京时间8点
  265. calendarData:[],//日历数据
  266. timeAxisData:[],//时间轴数据
  267. __Data:[],//当前的年月(日历)
  268. __xData:[],//当前的年月(时间轴)
  269. status:httpData['status'] || null,//任务状态(0未完成,1已完成,2已预约)
  270. searchTask:null,//快速查找任务:(1、我的任务,2、健康教育,3、健康指导,4、随访)
  271. planId: httpData['planId'],
  272. taskArr:[
  273. {code:1,name:'我的任务'},
  274. {code:2,name:'健康教育'},
  275. {code:3,name:'健康指导'},
  276. {code:4,name:'随访'},
  277. ],
  278. statusArr:[
  279. {code:0,name:'未完成'},
  280. {code:1,name:'已完成'},
  281. {code:2,name:'已预约'},
  282. ],
  283. curTask:'',//快速查找是否点击了搜索按钮
  284. tabStatus:null,
  285. },
  286. mounted:function(){
  287. this.tabStatus=1;
  288. if(!this.planId){
  289. layer.msg('为传入计划id(planId)',{icon:5})
  290. }
  291. },
  292. methods:{
  293. viewDetail:function(planids){
  294. if(!planids){
  295. layer.msg('无服务项',{icon:5})
  296. return ;
  297. }
  298. layer.open({
  299. type: 2,
  300. // offset: ['100px'], //右下角弹出
  301. area: ['600px', '650px'],
  302. shade: 0.5,
  303. title: '服务项目内容',
  304. fixed: true, //不固定
  305. maxmin: true,
  306. closeBtn:1,
  307. shift: 5,
  308. shadeClose: false, //点击遮罩关闭层
  309. content: '../../rehabilitation/html/service_item_content.html?planids='+planids
  310. });
  311. },
  312. changeStatus:function(val){
  313. this.status=this.status==val?null:val;
  314. },
  315. changeTask:function(val){
  316. this.searchTask=this.searchTask==val?null:val;
  317. },
  318. monDetail:function(){
  319. this.currentDay = this.ynow + '年'+ (this.mnow + 1) +'月';
  320. this.currentDayForEn=this.ynow+'/'+(this.mnow>=9?(this.mnow+1):"0"+(this.mnow+1))+'/'+(this.dnow>=9?this.dnow:"0"+this.dnow)
  321. },
  322. is_leap:function(year) { //判断是否为闰年
  323. return (year%100==0?res=(year%400==0?1:0):res=(year%4==0?1:0));
  324. },
  325. preMonth:function(){ //上一个月
  326. if(this.mnow<=0){
  327. this.mnow=11;
  328. this.ynow=this.ynow-1;
  329. }else{
  330. this.mnow--;
  331. }
  332. this.monDetail();
  333. this.goToLoadData(true);
  334. },
  335. getPreMouth:function(){
  336. var pMnow,pYnow;
  337. if(this.mnow<=0){
  338. pMnow=11;
  339. pYnow=this.ynow-1;
  340. }else{
  341. pMnow=this.mnow-1;
  342. pYnow=this.ynow;
  343. }
  344. var m_days=new Array(31,(28+this.is_leap(pYnow)),31,30,31,30,31,31,30,31,30,31); //每个月的天数
  345. return {
  346. days:m_days[pMnow],
  347. date:pYnow+'-'+(++pMnow>=10?pMnow:"0"+pMnow)
  348. }
  349. },
  350. nextMonth:function(){ //下一个月
  351. if(this.mnow>=11){
  352. this.mnow=0;
  353. this.ynow=this.ynow+1;
  354. }else{
  355. this.mnow++;
  356. }
  357. this.monDetail();
  358. this.goToLoadData(true);
  359. },
  360. getNextMouth:function(){
  361. var nMnow,nYnow;
  362. if(this.mnow>=11){
  363. nMnow=0;
  364. nYnow=this.ynow+1;
  365. }else{
  366. nMnow=this.mnow+1;
  367. nYnow=this.ynow;
  368. }
  369. var m_days=new Array(31,(28+this.is_leap(nYnow)),31,30,31,01,31,31,30,31,30,31); //每个月的天数
  370. return {
  371. days:m_days[nMnow],
  372. date:nYnow+'-'+(++nMnow>=10?nMnow:"0"+nMnow)
  373. }
  374. },
  375. goToLoadData:function(flag){//flag是否更新数据
  376. this.tabStatus==1 && (!this.calendarData.length || flag) && this.calendar();
  377. this.tabStatus==2 && (!this.timeAxisData.length || flag) && this.timeAxis();
  378. },
  379. calendar:function(){
  380. var nlstr = new Date(this.ynow,this.mnow,1); //当月第一天
  381. var firstday = nlstr.getDay()-1;//第一天星期几,默认是周日 我们改成周一
  382. firstday=firstday==-1?6:firstday;//如果是-1,说明当月的第一天是周日
  383. var m_days=new Array(31,(28+this.is_leap(this.ynow)),31,30,31,30,31,31,30,31,30,31); //每个月的天数
  384. var tr_str=Math.ceil((m_days[this.mnow] + firstday)/7); //当前月天数+第一天是星期几的数值 获得 表格行数
  385. var c_days=m_days[this.mnow];//当前月份的天数
  386. var p_arr=this.getPreMouth();
  387. var n_arr=this.getNextMouth();
  388. var i,k,idx,date_str;
  389. var dataArr=[];//天数/年月
  390. for(i=0;i<tr_str;i++) { //表格的行
  391. for(k=0;k<7;k++) { //表格每行的单元格
  392. idx=i*7+k; //单元格自然序列号
  393. date_str=idx-firstday+1; //计算日期
  394. var __ym;
  395. if(date_str<=0){//过滤无效日期(小于等于零的、大于月总天数的)
  396. date_str=date_str+p_arr['days'];//当前日期+上个月的天数就是上个月的日期
  397. __ym=p_arr['date'];
  398. }else if(date_str>c_days){
  399. date_str=date_str-c_days;//下个月的日期就是这个月的天数-当月的天数
  400. __ym=n_arr['date'];
  401. }else{
  402. __ym=this.ynow+'-'+(this.mnow>=9?"":"0")+(this.mnow+1);
  403. }
  404. dataArr.push({
  405. day:date_str,
  406. date:__ym
  407. });
  408. }
  409. }
  410. this.__Data=dataArr;
  411. this.monDetail();
  412. this.calenderPlanDetail();
  413. },
  414. // 日历请求
  415. calenderPlanDetail:function(){
  416. var vm=this;
  417. var __days=vm.__Data;
  418. var lastDay=(__days.concat()).pop().day;
  419. lastDay=lastDay>9?lastDay:'0'+lastDay;
  420. var params={
  421. executeStartTime:__days[0].date+'-'+__days[0].day+' 00:00:00',//日历开始时间(格式:yyyy-MM-dd HH:mm:ss)
  422. executeEndTime:(__days.concat()).pop().date+'-'+lastDay+' 23:59:59',//日历结束时间(格式:yyyy-MM-dd HH:mm:ss)
  423. planId:vm.planId,//计划id
  424. searchTask:vm.searchTask,//快速查找任务:(1、我的任务,2、健康教育,3、健康指导,4、随访)
  425. status:vm.status,//任务状态(0未完成,1已完成,2已预约)
  426. }
  427. rehaAPI.calendarPlanDetail(params).then(function(res){
  428. vm.curTask=vm.searchTask;
  429. vm.calendarData=[];
  430. if(res.status==200){
  431. var data=res.data
  432. for(var i in __days){
  433. var _key=__days[i].date+'-'+(__days[i].day>9?__days[i].day:'0'+__days[i].day);
  434. var item={
  435. noService:true,
  436. day:__days[i].day
  437. };
  438. for(var j in data){
  439. if(_key==j){
  440. item=data[j];
  441. item.day=__days[i].day;
  442. var finishFlag=false;
  443. var sFlag=false;
  444. var fFlag=false;
  445. if(item.specialist){
  446. if(item.specialist.all==item.specialist.finish){
  447. sFlag=true;
  448. }
  449. }else{
  450. sFlag = true;
  451. }
  452. if(item.family){
  453. if(item.family.all==item.family.finish){
  454. fFlag = true;
  455. }
  456. }else{
  457. fFlag = true;
  458. }
  459. finishFlag = sFlag && fFlag;
  460. item.finishFlag=finishFlag;
  461. data.length && data.splice(j,1);
  462. break;
  463. }
  464. }
  465. vm.calendarData.push(item);
  466. }
  467. }
  468. })
  469. },
  470. // 时间轴请求
  471. timeAxis:function(){
  472. var m_days=new Array(31,(28+this.is_leap(this.ynow)),31,30,31,30,31,31,30,31,30,31); //每个月的天数
  473. var c_days=m_days[this.mnow];//当前月份的天数
  474. var __ym=this.ynow+'-'+(this.mnow>=9?"":"0")+(this.mnow+1);
  475. var dataArr=[];//天数/年月
  476. for(;c_days>0;c_days--){
  477. dataArr.push({
  478. day:c_days,
  479. date:__ym
  480. });
  481. }
  482. this.__xData=dataArr;
  483. this.monDetail();
  484. this.calendarPlanDetailList();
  485. },
  486. // 时间轴请求
  487. calendarPlanDetailList:function(){
  488. var vm=this;
  489. var __days=vm.__xData;
  490. var lastDay=(__days.concat()).pop().day;
  491. lastDay=lastDay>9?lastDay:'0'+lastDay;
  492. var params={
  493. executeEndTime:__days[0].date+'-'+__days[0].day+' 00:00:00',//日历开始时间(格式:yyyy-MM-dd HH:mm:ss)
  494. executeStartTime:(__days.concat()).pop().date+'-'+lastDay+' 23:59:59',//日历结束时间(格式:yyyy-MM-dd HH:mm:ss)
  495. planId:vm.planId,//计划id
  496. searchTask:vm.searchTask,//快速查找任务:(1、我的任务,2、随访,3、复诊,4、健康教育)
  497. status:vm.status,//任务状态(0未完成,1已完成,2已预约)
  498. }
  499. rehaAPI.calendarPlanDetailList(params).then(function(res){
  500. if(res.status==200){
  501. var _currentTimeStamp=+new Date(vm.currentDayForEn);
  502. vm.timeAxisData=_.map(res.data||{},function(o){
  503. var _time=o.executeTime.split(' ');
  504. var thatTime=+new Date(_time[0]);
  505. var future=_currentTimeStamp>thatTime?0:(_currentTimeStamp==thatTime?1:2);
  506. var _html=o.status==2?'预':'';
  507. _html=future==1?'今':_html;
  508. if(_html=='预') future=3;
  509. o.html=_html
  510. o.date=_time[0];
  511. o.time=_time[1];
  512. o.future=future;
  513. return o;
  514. })||[];
  515. }
  516. console.log(vm.timeAxisData)
  517. })
  518. },
  519. },
  520. watch:{
  521. tabStatus:function(){
  522. this.goToLoadData();
  523. }
  524. }
  525. })
  526. }();
  527. </script>
  528. </body>
  529. </html>