gongzuobaogao.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434
  1. $(function() {
  2. var teamCode = '',
  3. tType = 0;
  4. //接口
  5. var pi = {
  6. ztqk: 'statistics/getStatTitleInfo',//总体情况
  7. zxtj: 'statistics/getReyStatbyTeam',//咨询统计
  8. jmgzqs: 'statistics/getConcernbyTeam',//居民关注趋势
  9. gzbhqs: 'statistics/getConcerAndCancel',//关注变化趋势
  10. jgnfw: 'statistics/getServiceRankingList',//机构内排行
  11. pjmyd: 'statistics/getAvgLine'//医生平均分
  12. };
  13. function openWebview(href,hrefId,extras) {
  14. if(plus.os.name == "Android") {
  15. var wv = plus.webview.create( href, hrefId, {hardwareAccelerated:false}, extras);
  16. wv.show("slide-in-right",250);
  17. } else {
  18. mui.openWindow({
  19. url:href,
  20. id:hrefId,
  21. extras:extras
  22. })
  23. }
  24. }
  25. var gzbg = {
  26. // 下拉
  27. $demoComtop: $('.demo-comtop'),
  28. $linMask: $('.lin-mask'),
  29. $linSelGroup: $('.lin-sel-group'),
  30. $selTit: $('#selTit'),
  31. // echarts
  32. $qyqkChart: document.getElementById('qyqkChart'),
  33. $zxtjChart: document.getElementById('zxtjChart'),
  34. $jmgzChart: document.getElementById('jmgzChart'),
  35. $gzbhChart: document.getElementById('gzbhChart'),
  36. $jgChart: document.getElementById('jgChart'),
  37. $mydChart: document.getElementById('mydChart'),
  38. //总体情况
  39. $qyrs: $('#qyrs'),
  40. $fwrs: $('#fwrs'),
  41. $pjmyd: $('#pjmyd'),
  42. //咨询统计
  43. $whfs: $('#whfs'),
  44. $yhfs: $('#yhfs'),
  45. $jgnph: $('.jgnph'),
  46. $zbdj: $('.zbdj'),
  47. //事件
  48. es: ['tap'],
  49. weeksData: null,
  50. monthData: null,
  51. type: 0,
  52. startDate: '',
  53. endDate: '',
  54. self: null,
  55. weeks: ['','第一周','第二周','第三周','第四周','第五周'],
  56. dateArr: [],
  57. init: function () {
  58. var me = this;
  59. me.self = plus.webview.currentWebview();
  60. teamCode = me.self.teamCode;
  61. me.bindEvent();
  62. me.setDate();
  63. },
  64. setDate: function () {
  65. if (this.type === 0) {
  66. this.startDate = $d.init(1);
  67. this.endDate = $d.init(2);
  68. } else {
  69. this.startDate = $d.init(3);
  70. this.endDate = $d.init(4);
  71. }
  72. if (this.weeksData === null || this.monthData === null) {
  73. this.loadDate();
  74. } else {
  75. this.setDateInPage();
  76. }
  77. },
  78. getZTQKData: function () {//总体情况
  79. return getReqPromise( pi.ztqk, {
  80. startDate: this.startDate,
  81. endDate: this.endDate
  82. }, 'GET');
  83. },
  84. getZXTJData: function () {//咨询统计
  85. return getReqPromise( pi.zxtj, {
  86. startDate: this.startDate,
  87. endDate: this.endDate,
  88. isNow: 1
  89. }, 'GET');
  90. },
  91. getJMGZQSData: function () {//居民关注趋势
  92. return getReqPromise( pi.jmgzqs, {
  93. startDate: this.startDate,
  94. endDate: this.endDate,
  95. type: this.type
  96. }, 'GET');
  97. },
  98. getGZBHQSData: function () {//关注变化趋势
  99. return getReqPromise( pi.gzbhqs, {
  100. startDate: this.startDate,
  101. endDate: this.endDate,
  102. type: this.type
  103. }, 'GET');
  104. },
  105. getJGNFWData: function () {//机构内排行
  106. return getReqPromise( pi.jgnfw, {
  107. startDate: this.startDate,
  108. endDate: this.endDate
  109. }, 'GET');
  110. },
  111. getPJMYDData: function () {//医生平均分
  112. return getReqPromise( pi.pjmyd, {
  113. startDate: this.startDate,
  114. endDate: this.endDate,
  115. type: this.type
  116. }, 'GET');
  117. },
  118. loadDate: function () {
  119. var me = this;
  120. plus.nativeUI.showWaiting();
  121. Promise.all([ me.getZTQKData(), me.getZXTJData(),me.getJMGZQSData(),me.getGZBHQSData(),me.getJGNFWData(),me.getPJMYDData()]).then(function (ress) {
  122. if (me.type === 0) {
  123. me.weeksData = ress;
  124. }
  125. if (me.type === 1) {
  126. me.monthData = ress;
  127. }
  128. // console.error(JSON.stringify(ress))
  129. // console.error(JSON.stringify(ress[3]))
  130. me.setDateInPage();
  131. plus.nativeUI.closeWaiting();
  132. });
  133. },
  134. setDateInPage: function () {
  135. var me = this,
  136. data = me.type === 0 ? me.weeksData : me.type === 1 ? me.monthData : [],
  137. d = [],
  138. qyrs = 0,
  139. fwrs = 0,
  140. pjmyd = 0,
  141. whfs = 0,
  142. yhfs = 0;
  143. if (data[0].status == 200) {
  144. d= data[0].data;
  145. qyrs = d[7].concernCount;
  146. fwrs = d[1].consultCount + d[2].reservationCount + d[3].articleCount + d[4].guidanceCount + d[5].followupCount;
  147. pjmyd = d[6].avgScore;
  148. }
  149. if (data[1].status == 200) {
  150. whfs = data[1].data.onReyCount;
  151. yhfs = data[1].data.totalCount;
  152. }
  153. me.$qyrs.html(qyrs);//qyrs
  154. me.$fwrs.html("-");//fwrs
  155. if(pjmyd==0){
  156. me.$pjmyd.html("暂无评分");
  157. }else{
  158. me.$pjmyd.html(pjmyd);
  159. }
  160. //咨询统计
  161. me.$whfs.html(whfs);
  162. me.$yhfs.html(yhfs);
  163. me.initChartsData();
  164. },
  165. initChartsData: function () {
  166. var me = this,
  167. data = me.type === 0 ? me.weeksData : me.type === 1 ? me.monthData : [],
  168. qy = {dt:[],da:[]},
  169. zxtj = [],
  170. jgnfw = [],
  171. jmgzqs = [],
  172. gzbhqs = {},
  173. pjmyd = {dt:[],da:[]},
  174. xqzq = {da1: [], da2: []},
  175. dArr = $d.init(5);
  176. me.dateArr = $d.init(6);
  177. if (data[1].status == 200) {
  178. zxtj = data[1].data;
  179. }
  180. if (data[0].status == 200) {
  181. var datas = data[0];
  182. jgnfw = [datas.data[1].consultCount, datas.data[5].followupCount, datas.data[2].reservationCount, datas.data[4].guidanceCount, datas.data[3].articleCount];
  183. }
  184. if (data[4].status == 200) {
  185. var html = '';
  186. html += '<li>' + (data[4].data[0].consultRK ? ('第' + data[4].data[0].consultRK + '名') : '未上榜') + '</li>';
  187. html += '<li>' + (data[4].data[3].guidanceRK ? ('第' + data[4].data[3].guidanceRK + '名') : '未上榜') + '</li>';
  188. html += '<li>' + (data[4].data[4].articleRK ? ('第' + data[4].data[4].articleRK + '名') : '未上榜') + '</li>';
  189. me.$jgnph.html(html);
  190. }
  191. if (data[5].status == 200) {
  192. pjmyd = me.getDataXY(data[5].data, 2);
  193. if (me.type === 0) {
  194. // me.dateArr = $d.init(5);
  195. pjmyd = $h.contrastDate( dArr, pjmyd, 'dt', 'da');
  196. }
  197. if (me.type === 1) {
  198. var d1 = $h.getWeeksData( pjmyd, 'dt', 'da'),
  199. pjmyd = d1.da;
  200. me.dateArr = d1.dt;
  201. }
  202. }
  203. if(data[2].status == 200){
  204. jmgzqs = me.getDataXY(data[2].data, 3);
  205. if (me.type === 0) {
  206. // me.dateArr = $d.init(5);
  207. jmgzqs = $h.contrastDate(dArr, jmgzqs, 'dt', 'da');
  208. }
  209. if (me.type === 1) {
  210. var d1 = $h.getWeeksData( jmgzqs, 'dt', 'da'),
  211. jmgzqs = d1.da;
  212. me.dateArr = d1.dt;
  213. }
  214. }
  215. //处理关注变化趋势
  216. if(data[3].status == 200){
  217. gzbhqs = data[3].data;
  218. var concorn = gzbhqs[0].concorn//新增关注
  219. var cancel = gzbhqs[0].cancel;//取消关注
  220. concorn = me.getDataXY(concorn, 3);
  221. cancel = me.getDataXY(cancel, 4);
  222. if (me.type === 0) {
  223. concorn = $h.contrastDate(dArr, concorn, 'dt', 'da');
  224. cancel = $h.contrastDate(dArr, cancel, 'dt', 'da');
  225. }
  226. if (me.type === 1) {
  227. var d1 = $h.getWeeksData( concorn, 'dt', 'da');
  228. var d2 = $h.getWeeksData( cancel, 'dt', 'da');
  229. concorn = d1.da;
  230. cancel = d2.da;
  231. me.dateArr = d1.dt;
  232. }
  233. gzbhqs = {concorn:concorn,cancel:cancel}
  234. }
  235. me.loadCharts(qy, zxtj, jgnfw, pjmyd, jmgzqs, gzbhqs);
  236. },
  237. loadCharts: function(qy, zxtj, jgnfw, pjmyd, jmgzqs, gzbhqs) {
  238. var me = this,gzbhxAxisData=[],gzbhSeriesData1=[],gzbhSeriesData2=[];
  239. var count = zxtj.onReyCount + zxtj.totalCount;
  240. var zx = count == 0 ? (1/2)*100 : 0;
  241. jgnfw.splice(1,2);//删除随访和代预约的值
  242. //处理咨询统计
  243. var unreplay = zxtj.onReyCount, //未回复数
  244. total = zxtj.totalCount,
  245. replay = parseInt(total) - parseInt(unreplay); //已回复咨询数
  246. $("#totalCount").text(total);//总咨询数
  247. Promise.all([
  248. //咨询统计
  249. $ic.init({
  250. el: me.$zxtjChart,
  251. seriesData: [{
  252. name: '未回复咨询',
  253. value: unreplay || zx
  254. }, {
  255. name: '已回复咨询',
  256. value: replay || zx
  257. }],
  258. chartsType: 2,
  259. seriesName:"咨询数量"
  260. }),
  261. //机构内服务
  262. $ic.init({
  263. el: me.$jgChart,
  264. xAxisData: ['咨询', '指导', '教育'],//['咨询', '随访', '代预约', '指导', '教育']
  265. seriesData: jgnfw,
  266. chartsType: 3,
  267. color: '#fbba31',
  268. cb: me.eConsole
  269. }),
  270. //平均医生评分
  271. $ic.init({
  272. el: me.$mydChart,
  273. xAxisData: me.dateArr,
  274. seriesData: me.setSeries(1, pjmyd),
  275. chartsType: 1,
  276. }),
  277. //居民关注趋势
  278. $ic.init({
  279. el: me.$jmgzChart,
  280. xAxisData: me.dateArr,
  281. seriesData: me.setSeries(2, jmgzqs),
  282. chartsType: 1
  283. }),
  284. //关注变化趋势
  285. $ic.init({
  286. el: me.$gzbhChart,
  287. xAxisData: me.dateArr,
  288. legend: {
  289. data:['新增关注','取消关注']
  290. },
  291. seriesData: [{
  292. name:"新增关注",
  293. type: "line",
  294. symbol: "emptyCircle",
  295. data: gzbhqs.concorn
  296. },
  297. {
  298. name:"取消关注",
  299. type: "line",
  300. symbol: "emptyCircle",
  301. data: gzbhqs.cancel
  302. }],
  303. chartsType: 1
  304. }),
  305. ]);
  306. },
  307. getDataXY: function ( d, t) {
  308. var data = {dt:[],da:[]};
  309. if (this.type == 0) {
  310. for (var i = 0, len = d.length; i< len; i++) {
  311. data.dt.push(t == 1 ? d[i].applyDate : t == 2 ?d[i].dateNo:d[i].applyDate);
  312. data.da.push(t == 1 ? d[i].signCount : t == 2 ?d[i].avgCount:t == 4?d[i].cancelCount:d[i].concernCount);
  313. }
  314. return data;
  315. }
  316. if (this.type == 1) {
  317. for (var i = 0, len = d.length; i< len; i++) {
  318. data.dt.push(t == 1 ? d[i].weekOfMonth : t == 2 ?d[i].weekNo:d[i].weekOfMonth);
  319. data.da.push(t == 1 ? d[i].signCount : t == 2 ?d[i].avgCount:t == 4?d[i].cancelCount:d[i].concernCount);
  320. }
  321. return data;
  322. }
  323. },
  324. getXQDataXY: function ( d, t) {
  325. var data = {dt:[],da:[]};
  326. for (var i = 0, len = d.length; i< len; i++) {
  327. if (this.type === 0) {
  328. data.dt.push(d[i].dateNo);
  329. }
  330. if (this.type === 1) {
  331. data.dt.push(d[i].weekOfMonth);
  332. }
  333. data.da.push(t == 1 ? d[i].inCount : d[i].outCount);
  334. }
  335. return data;
  336. },
  337. setSeries: function ( type, seriesData) {
  338. return [{
  339. name: type == 1 ? '医生评分' :'居民关注' ,
  340. type: "line",
  341. symbol: "emptyCircle",
  342. data: seriesData
  343. }]
  344. },
  345. bindEvent: function () {
  346. var me = this;
  347. $h.setEvent([
  348. [ me.$demoComtop, me.es[0], function () {
  349. me.xlEventFun( this, me);
  350. }, 'h1'],
  351. [ me.$linMask, me.es[0], function () {
  352. $(this).hide();
  353. me.$linSelGroup.hide();
  354. }],
  355. [ me.$linSelGroup, me.es[0], function () {
  356. me.switchWeeksToMonth( this, me);
  357. }, 'li'],
  358. ]);
  359. },
  360. //周月切换
  361. switchWeeksToMonth: function ( that, me) {
  362. var type = $(that).attr('data-type');
  363. $(that).siblings().removeClass('checked');
  364. $(that).addClass('checked');
  365. me.$selTit.html($(that).find('label').html());
  366. me.$linMask.hide();
  367. me.$linSelGroup.hide();
  368. me.type = parseInt(type);
  369. tType = me.type;
  370. this.setDate();
  371. },
  372. //下拉
  373. xlEventFun: function ( thst, me) {
  374. var lCss = me.$linMask.css('display');
  375. if (lCss == 'none') {
  376. me.$linMask.show();
  377. me.$linSelGroup.show();
  378. } else {
  379. me.$linMask.hide();
  380. me.$linSelGroup.hide();
  381. }
  382. },
  383. eConsole: function (param) {
  384. // return;
  385. if(typeof param.seriesIndex != 'undefined') {
  386. switch(param.dataIndex) {
  387. case 0:
  388. openWebview('../html/tuanduizixunxiangqing.html', 'tuanduizixunxiangqing', {
  389. teamCode: teamCode,
  390. type: tType
  391. })
  392. break;
  393. case 1:
  394. openWebview('../html/tuanduisuifangxiangqing.html', 'tuanduisuifangxiangqing', {
  395. teamCode: teamCode,
  396. type: tType
  397. })
  398. break;
  399. case 2:
  400. openWebview('../html/tuanduidaiyuyuexiangqing.html', 'tuanduidaiyuyuexiangqing', {
  401. teamCode: teamCode,
  402. type: tType
  403. })
  404. break;
  405. case 3:
  406. openWebview('../html/tuanduizhidaoxiangqing.html', 'tuanduizhidaoxiangqing', {
  407. teamCode: teamCode,
  408. type: tType
  409. })
  410. break;
  411. case 4:
  412. openWebview('../html/tuanduijiaoyuxiangqing.html', 'tuanduijiaoyuxiangqing', {
  413. teamCode: teamCode,
  414. type: tType
  415. })
  416. break;
  417. default:
  418. break;
  419. }
  420. }
  421. }
  422. };
  423. mui.init();
  424. mui.plusReady(function(){
  425. gzbg.init();
  426. });
  427. });