insurance.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407
  1. new Vue({
  2. el: '#app',
  3. data: {
  4. pickerOptions0: {
  5. disabledDate:function(time) {
  6. return time.getTime() > Date.now() - 8.64e6
  7. }},
  8. city: '上饶市',
  9. town: [],
  10. selectTown:["0"],
  11. cityVal:"0",
  12. timeType: '1', //时间过滤条件 1是上月 2是半年
  13. leftData1: {}, //左边数据块1
  14. leftData2: {}, //左边数据块2
  15. bakLeftData1:{},//缓存左边数据块1
  16. bakLeftData2:{},//缓存左边数据块2
  17. yesterdayData: {},
  18. leftChart1: null, //左边的图表1
  19. leftChart2: null, //左边的图表2
  20. leftData3:null,//左边的图表3
  21. leftData2_legend:null,//左边的图表2中间数据
  22. tableData1: null, //表格数据1
  23. tableData2: null, //表格数据2
  24. mapData: null,
  25. allData: null, //所有的数据 用来切换区县
  26. lineHeightIndex: null,
  27. skipShow: 0,
  28. hasData1:true,
  29. hasData2:true,
  30. hasData3:true,
  31. hasData4:true,
  32. hasData5:true,
  33. hasData6:true,
  34. hasMapData:true,
  35. time:'',
  36. middleData1:'',
  37. middleData2:'',
  38. middleData3:'',
  39. linkageFilter1:'',
  40. linkageFilter3:'',
  41. },
  42. mounted: function() {
  43. var _nowMonth;
  44. nowMonth == '0'?_nowMonth = 12:_nowMonth=nowMonth
  45. this.time = new Date(nowYear+'-'+ (_nowMonth))
  46. this.linkageFilter1 = "quotaDate >= '" + getLastMonthStartDate() + "' and quotaDate <= '" + getLastMonthEndDate() + "';";
  47. this.linkageFilter2 = "quotaDate >= '" + getHalfYearStartDate() + "' and quotaDate <= '" + getHalfYearEndDate() + "';";
  48. this.initData();
  49. },
  50. filters:{
  51. formatData:function(value){
  52. if(value>100000){
  53. if(value>1000000000){
  54. return (value/100000000).toFixed(2)+"亿"
  55. }else{
  56. return (value/10000).toFixed(2)+"万"
  57. }
  58. }else{
  59. return value
  60. }
  61. }
  62. },
  63. methods: {
  64. initData: function() {
  65. this.timeType = 1;//默认显示本月
  66. $(".div-mask-layer").show();
  67. var vm = this;
  68. // debugger
  69. // 这个月
  70. var linkageFilter1 = this.linkageFilter1
  71. // console.log(linkageFilter1)
  72. if(vm.cityVal!="0") {
  73. linkageFilter1 += "town=" + vm.cityVal[0] + ";";
  74. if(vm.cityVal[1]){
  75. linkageFilter1 += "org='" + vm.cityVal[1] + "';";
  76. }
  77. }
  78. // 半年
  79. var linkageFilter2 = this.linkageFilter2
  80. if(vm.cityVal!="0") {
  81. linkageFilter2 += "town=" + vm.cityVal[0] + ";";
  82. if(vm.cityVal[1]){
  83. linkageFilter2 += "org='" + vm.cityVal[1] + "';";
  84. }
  85. }
  86. // console.log(linkageFilter2)
  87. // 本月,没有地区条件
  88. var linkageFilter3 = vm.linkageFilter1;
  89. // console.log(linkageFilter3)
  90. var reqUrl = [{url: bigDataAPI.getCityHospital,reqType: 'get',data: {}},
  91. {url: bigDataAPI.getNoChartTemplateData,reqType: 'get',data: {viewCodeStr: "VIEW_22_0004",linkageFilter:linkageFilter1}},//医保费用
  92. {url: bigDataAPI.getTemplateDataByViewCode,reqType: 'get',data: {viewCode: "VIEW_22_0003",linkageFilter:linkageFilter2}},//医保支出费用月趋势
  93. {url: bigDataAPI.getTemplateDataByViewCode,reqType: 'get',data: {viewCode: "VIEW_22_0002",linkageFilter:linkageFilter1}},//医保目录外费用占比
  94. {url: bigDataAPI.getTemplateDataByViewCode,reqType: 'get',data: {viewCode: "VIEW_22_0005",linkageFilter:linkageFilter1}},//
  95. {url:bigDataAPI.getMapJingWeiDuInfo,reqType: 'get',data:{}},//上饶地图经纬度数据
  96. {url: bigDataAPI.getNoChartTemplateData,reqType: 'get',data: {viewCodeStr: "VIEW_22_0001",linkageFilter:linkageFilter1,limitCondition:JSON.stringify({'VIEW_22_0001': '50'})}},//机构排行
  97. {url: bigDataAPI.getNoChartTemplateData,reqType: 'get',data: {viewCodeStr: "VIEW_22_0006",linkageFilter:linkageFilter1,limitCondition:JSON.stringify({'VIEW_22_0006': '50'})}},//疾病
  98. {url: bigDataAPI.getNoChartTemplateData,reqType: 'get',data: {viewCodeStr: "VIEW_22_0004",linkageFilter:linkageFilter3}}//医保费用地图数据
  99. ];
  100. // debugger
  101. httpRequest.getReqPromises(reqUrl).then(function(datas) {
  102. vm.town = datas[0].map((item, index, arr) => {
  103. item.children.map((t) => {
  104. return t.label = t.text;
  105. })
  106. item.label = item.text;
  107. return item;
  108. })
  109. vm.town.unshift({
  110. label: '上饶市',
  111. value: '0'
  112. })
  113. // debugger
  114. // console.log(datas[1])
  115. vm.middleData1 = toThousands(datas[1].obj.VIEW_22_0004[0].HC_22_1001/10000);
  116. vm.middleData3 = toThousands(datas[1].obj.VIEW_22_0004[0].HC_22_1006/10000);
  117. if(vm.middleData3 != "0"){
  118. vm.middleData2 = ((datas[1].obj.VIEW_22_0004[0].HC_22_1001-datas[1].obj.VIEW_22_0004[0].HC_22_1006)/datas[1].obj.VIEW_22_0004[0].HC_22_1006*100).toFixed(2);
  119. }else{
  120. vm.middleData2 = 0
  121. }
  122. console.log(vm.middleData2)
  123. if(vm.middleData2 == 'NaN'){
  124. vm.middleData2 = 0;
  125. }
  126. var chart2 = datas[2].obj.viewInfos[0].options[0].option;
  127. // vm.leftData1 = datas[1];
  128. var chart3 = datas[3].obj.viewInfos[0].options[0].option;
  129. var chart4 = datas[4].obj.viewInfos[0].options[0].option;
  130. var data5 = datas[5];
  131. var data6 = datas[6];
  132. var data7 = datas[7];
  133. var data8 = datas[8];
  134. vm.setLeftChart1(chart2);
  135. vm.setLeftChart2(chart3);
  136. vm.setLeftChart3(chart4);
  137. vm.setTable1(data6)
  138. vm.setTable2(data7)
  139. echarts.registerMap('上饶',data5);
  140. vm.setMapData(data8);
  141. vm.setYesterDay(data8);
  142. $(".div-mask-layer").hide();
  143. })
  144. },
  145. setleftData1: function() {
  146. var options = {},options1={},options2={},vm=this;
  147. if(this.leftData1.successFlg) {
  148. _.map(vm.leftData1.obj.VIEW_14_0011,function(item,index){
  149. if(vm.cityVal=="0"){//上饶市
  150. options1 = vm.leftData1.obj.VIEW_14_0011[0];
  151. }else if(item.firstColumn==vm.city){
  152. options1 = item;
  153. }
  154. })
  155. }
  156. if(this.leftData2.successFlg) {
  157. _.map(vm.leftData2.obj.VIEW_14_0011,function(item,index){
  158. if(vm.cityVal=="0"){//上饶市
  159. options2 = vm.leftData2.obj.VIEW_14_0011[0];
  160. }else if(item.firstColumn==vm.city){
  161. options2 = item;
  162. }
  163. })
  164. }
  165. vm.bakLeftData1 = this.setFormater(options1);
  166. vm.bakLeftData2 = this.setFormater(options2);
  167. this.leftData = vm.bakLeftData1;
  168. },
  169. setYesterDay: function(data3) {
  170. var options = {},vm=this;
  171. if(data3.successFlg) {
  172. _.map(data3.obj&&data3.obj.VIEW_14_0012||[],function(item,index){
  173. if(vm.cityVal=="0"){//上饶市
  174. options = data3.obj.VIEW_14_0012[0];
  175. }else if(item.firstColumn==vm.city){
  176. options = item;
  177. }
  178. })
  179. }
  180. if(options){
  181. this.setFormater(options);
  182. this.yesterdayData = options;
  183. }
  184. },
  185. setLeftChart1: function(data) {
  186. var options = JSON.parse(data);
  187. options = leftChart1(options);
  188. this.leftData1 = options;
  189. },
  190. setLeftChart2: function(data) {
  191. var options = JSON.parse(data);
  192. this.leftData2_legend = null;
  193. if(options.series[0].data[0] && options.series[0].data[1]){
  194. if(options.series[0].data[0].value && options.series[0].data[1].value){
  195. this.leftData2_legend = toThousands((Number(options.series[0].data[0].value)+Number(options.series[0].data[1].value))/10000)
  196. }
  197. }
  198. options = leftChart2(options);
  199. this.leftData2 = options;
  200. },
  201. setLeftChart3: function(data) {
  202. // debugger
  203. var options = JSON.parse(data);
  204. options = leftChart3(options);
  205. this.leftData3 = options;
  206. },
  207. setMapData: function(data3) {
  208. // debugger
  209. var optionData = [];
  210. _.map(data3.obj&&data3.obj.VIEW_22_0004||[], function(item) {
  211. if(item.firstColumn != "合计") {
  212. optionData.push({
  213. name: item.town,
  214. value: parseInt(item.HC_22_1001)
  215. })
  216. }
  217. })
  218. if(optionData.length>0){
  219. var options = optionData;
  220. this.mapData = {
  221. data: options,
  222. index: this.lineHeightIndex
  223. };
  224. this.hasMapData = true;
  225. }else{
  226. this.hasMapData = false;
  227. }
  228. },
  229. setTable1: function(data) {
  230. var arr = data.obj.VIEW_22_0001;
  231. arr.shift()
  232. arr = arr.map(function(item){
  233. item.HC_22_1001 = toThousands(Number(item.HC_22_1001)/10000)
  234. return item;
  235. })
  236. if(arr.length == 0){
  237. this.tableData1 = false;
  238. }else{
  239. this.tableData1 = arr;
  240. }
  241. // console.log(this.tableData1)
  242. },
  243. setTable2: function(data) {
  244. // console.log(data)
  245. var arr = data.obj.VIEW_22_0006;
  246. arr.shift()
  247. arr = arr.map(function(item){
  248. if(item.HC_22_1004 == 0){
  249. return item;
  250. }
  251. item.HC_22_1004 = toThousands(Number(item.HC_22_1004)/10000)
  252. return item;
  253. })
  254. if(arr.length == 0){
  255. this.tableData2 = false;
  256. }else{
  257. this.tableData2 = arr;
  258. }
  259. // console.log(this.tableData2)
  260. },
  261. setCity(item) {
  262. this.city = item.name;
  263. },
  264. setTimeStr(v) {
  265. this.timeType = v;
  266. this.timeType == 1?this.leftData=this.bakLeftData1:this.leftData=this.bakLeftData2;
  267. },
  268. setFormater: function(obj) {
  269. for(var c in obj) {
  270. if(obj[c].toString().indexOf(",") == -1){//不存在,,说明要格式化
  271. var re = /^[0-9]+.?[0-9]*/;//判断字符串是否为数字//判断正整数/[1−9]+[0−9]∗]∗/
  272. if (!re.test(obj[c])) { //不是数字,则不格式化
  273. continue;
  274. }
  275. if(obj[c]>100000){
  276. obj[c] = (obj[c]/10000).toFixed(2)+"万"
  277. }else{
  278. obj[c] = toThousands(obj[c]);
  279. }
  280. }
  281. }
  282. return obj;
  283. },
  284. newObj: function(obj) {
  285. return JSON.parse(JSON.stringify(obj))
  286. },
  287. clickMap: function(res) {
  288. var vm = this;
  289. // console.log(res)
  290. this.city = res.name;
  291. // console.log(this.town)
  292. var k = null;
  293. this.town.map(function(item,index){
  294. if(item.label == res.name){
  295. k = item.value
  296. }
  297. if(item.label == vm.city) {
  298. vm.cityVal = item.value;
  299. }
  300. })
  301. this.selectTown = [];
  302. this.selectTown.push(k);
  303. },
  304. skipClick: function() {
  305. // console.log(222)
  306. this.skipShow == 0 ? this.skipShow = 1 : this.skipShow = 0
  307. },
  308. areaChange:function(data){
  309. console.log(data)
  310. console.log(this.town)
  311. var cityValue = [],city=null;
  312. this.town.map(function(item,index){
  313. if(item.value == data[0]){
  314. cityValue.push(item.value);
  315. city = item.label
  316. if(data[1]){
  317. item.children.map(function(t){
  318. if(t.value == data[1]){
  319. cityValue.push(t.value)
  320. }
  321. })
  322. }
  323. }
  324. })
  325. console.log(cityValue)
  326. this.cityVal = cityValue;
  327. this.city = city;
  328. },
  329. clickTime:function(data){
  330. // console.log(data);
  331. var year = data.substring(0,4);
  332. var month = data.substring(5,7);
  333. var linkageFilter1 = "quotaDate >= '" + data +"-01' and quotaDate <= '" + data+'-'+getDaysInMonth(year,month)+"';"
  334. var linkageFilter2 = "quotaDate >= '" + getLastHalfMonthArray(data) +"' and quotaDate <= '" + data+'-'+getDaysInMonth(year,month)+"';"
  335. this.linkageFilter1 = linkageFilter1;
  336. this.linkageFilter2 = linkageFilter2;
  337. this.initData();
  338. }
  339. },
  340. watch: {
  341. cityVal: function(value) {
  342. // console.log(value)
  343. var that = this;
  344. that.lineHeightIndex = this.city;
  345. // this.selectTown = value;
  346. this.initData();
  347. }
  348. }
  349. });
  350. //数字格式化
  351. function toThousands(num) {
  352. if (!num && num !== 0) return ''
  353. if (typeof (num) == 'number') {
  354. num = num.toString()
  355. }
  356. var str = ''
  357. if (num.indexOf('.') != -1) {
  358. num = Number(num).toFixed(2);
  359. str = num.split('.')[1];
  360. num = num.split('.')[0];
  361. }
  362. if (str) {
  363. str = '.' + str
  364. }
  365. return (num || 0).toString().replace(/(\d)(?=(?:\d{3})+$)/g, '$1,') + str;
  366. }
  367. document.getElementById("full").onclick = function (event) {
  368. var app = document.getElementById('app');
  369. console.log()
  370. if($("#full").attr('src') == "../images/full-q.png"){
  371. $("#full").attr('src',"../images/full-s.png")
  372. FullScreen(app);
  373. }else{
  374. $("#full").attr('src',"../images/full-q.png")
  375. exitfullscreen()
  376. }
  377. }
  378. function FullScreen() {
  379. var el = document.documentElement;
  380. var rfs = el.requestFullScreen || el.webkitRequestFullScreen || el.mozRequestFullScreen || el.msRequestFullScreen; //定义不同浏览器的全屏API
  381. //执行全屏
  382. if (typeof rfs != "undefined" && rfs) {
  383. debugger
  384. rfs.call(el);
  385. } else if (typeof window.ActiveXObject != "undefined") {
  386. var wscript = new ActiveXObject("WScript.Shell");
  387. if (wscript != null) {
  388. debugger
  389. wscript.SendKeys("{F11}");
  390. }
  391. }
  392. }
  393. function exitfullscreen() { //退出全屏
  394. if (document.exitFullscreen) {
  395. document.exitFullscreen();
  396. }
  397. else if (document.mozCancelFullScreen) {
  398. document.mozCancelFullScreen();
  399. }
  400. else if (document.webkitCancelFullScreen) {
  401. document.webkitCancelFullScreen();
  402. }
  403. else if (document.msExitFullscreen) {
  404. document.msExitFullscreen();
  405. }
  406. }