consulting-analysis.js 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336
  1. var reqList = [];
  2. new Vue({
  3. el: "#main",
  4. data: {
  5. appname: "咨询分析",
  6. isback: true,
  7. isrefresh: true,
  8. isfilter: true,
  9. isopen: true,
  10. //页面请求参数
  11. level: '',
  12. area: '',
  13. areaTitle: '',
  14. lowLevel: '',
  15. chooseYear: '',
  16. endDate: '',
  17. topDatas: {
  18. total: 0,
  19. noRelyCount: 0,
  20. noRelyRate: 0,
  21. relyRate: 0
  22. }
  23. },
  24. components: {
  25. vuedals: Vuedals.Component
  26. },
  27. methods:{
  28. getAreaData: function(arg){
  29. //如果level改变,则需要重新加载整个页面的数据,否则只需加载底部区域数据
  30. if(arg.level == this.level){
  31. this.lowLevel = arg.lowLevel;
  32. loadData([2], this);
  33. }else{
  34. this.level = arg.level;
  35. this.lowLevel = arg.lowLevel;
  36. this.area = arg.area;
  37. this.areaTitle = arg.areaTitle;
  38. loadData([0,1,2], this);
  39. }
  40. EventBus.$emit('update-area-name', {areaName: this.areaTitle});
  41. //存储请求所带的参数
  42. reqList.push({
  43. level: this.level,
  44. area: this.area,
  45. areaTitle: this.areaTitle,
  46. lowLevel: this.lowLevel,
  47. endDate: this.endDate
  48. })
  49. }
  50. },
  51. mounted: function(){
  52. //初始化数据
  53. initData(this);
  54. //获得顶部各tab的值
  55. loadData([0,1,2], this); //参数组数表示请求的区域为上中下
  56. //存储请求所带的参数
  57. reqList.push({
  58. level: this.level,
  59. area: this.area,
  60. areaTitle: this.areaTitle,
  61. index: this.index,
  62. endDate: this.endDate,
  63. startDate: this.startDate,
  64. lowLevel: this.lowLevel
  65. });
  66. //设置监听器, 监听折线图日期变化
  67. var vm = this;
  68. //监听后退按钮的操作
  69. EventBus.$on("back-click", function(arg){
  70. if(reqList.length == 1){
  71. history.go(-1);
  72. }
  73. else{
  74. var preInfo = reqList.pop();
  75. var info = reqList[reqList.length - 1];
  76. vm.level = info.level;
  77. vm.area = info.area;
  78. vm.areaTitle = info.areaTitle;
  79. vm.lowLevel = info.lowLevel;
  80. vm.index = info.index;
  81. loadData([0,1,2], vm);
  82. EventBus.$emit('update-area-name', {areaName: vm.areaTitle});
  83. }
  84. });
  85. //监听页面刷新
  86. EventBus.$on("refresh-click", function(arg){
  87. loadData([0,1,2], vm);
  88. });
  89. //弹出筛选框
  90. EventBus.$on('filter-click', function(arg) {
  91. //弹框显示筛选条件
  92. Vuedals.Bus.$emit('new', {
  93. title: '条件筛选',
  94. onClose:function(data){
  95. console.log(data);
  96. vm.chooseYear = data.chooseYear;
  97. vm.endDate = getEndDate(vm.chooseYear);
  98. loadData([0, 1, 2], vm);//刷新数据
  99. EventBus.$emit('update-statistics-year', {selectDate: vm.chooseYear + "年"});//更新年份
  100. EventBus.$emit('update-statistics-time', {});//更新统计时间
  101. },
  102. component: 'year-filter',
  103. props: {
  104. selectedYear: vm.chooseYear
  105. }
  106. });
  107. });
  108. $("#main").removeClass("c-hide");
  109. }
  110. });
  111. function initData(vm){
  112. //获得缓存中缓存的角色权限
  113. var userRole = window.localStorage.getItem("selectedRole");
  114. if(!userRole){
  115. return false;
  116. }
  117. vm.userRole = JSON.parse(userRole);
  118. vm.level = vm.userRole.code == '350200' ? 4 : vm.userRole.code.length == 6 ? 3 : 2;
  119. vm.area = vm.userRole.code;
  120. vm.areaTitle = vm.userRole.name;
  121. EventBus.$emit('update-area-name', {areaName: vm.areaTitle});
  122. var now = new Date();
  123. if(now.getMonth() >= 6){
  124. vm.chooseYear = now.getFullYear();
  125. }else{
  126. vm.chooseYear = now.getFullYear() - 1;
  127. }
  128. vm.endDate = getEndDate(vm.chooseYear);
  129. EventBus.$emit('update-statistics-year', {selectDate: vm.chooseYear + "年"});
  130. }
  131. function initReqParams(vm){
  132. var param = [{
  133. url: "/statistics/Consulting_Title",
  134. data: {level: vm.level, area: vm.area, year: vm.chooseYear}
  135. },{
  136. url: "/statistics/getCoutListByTime",
  137. data: {level: vm.level, area: vm.area, year: vm.chooseYear}
  138. },{
  139. url: "/statistics/Consulting_StatList",
  140. data: {level: vm.level, area: vm.area, year: vm.chooseYear, sort: 1, date: vm.endDate, lowlevel: vm.lowLevel}
  141. }];
  142. return param;
  143. }
  144. function loadData(loadArr, vm){
  145. //获取其他请求的参数
  146. var reqParams = initReqParams(vm),
  147. reqPromise = [];
  148. for(i=0; i< loadArr.length; i++){
  149. var j = loadArr[i];
  150. var param = reqParams[j];
  151. reqPromise.push(httpRequest.get(param.url, {data: param.data}));
  152. }
  153. if(reqPromise.length > 0){
  154. Promise.all(reqPromise).then(function(ress){
  155. var res1, res2, res2;
  156. for(var i=0; i<loadArr.length; i++){
  157. var j = loadArr[i] + 1;
  158. if(j == 1){
  159. res1 = ress[i];
  160. }
  161. if(j == 2){
  162. res2 = ress[i];
  163. }
  164. if(j == 3){
  165. res3 = ress[i];
  166. }
  167. }
  168. if(res1){
  169. if(res1.status == 200){
  170. handleTopPanelData(res1.data, vm);
  171. }else{
  172. console.log(res1.msg);
  173. }
  174. }
  175. if(res2){
  176. if(res2.status == 200){
  177. handleSecondPanelData(res2.data, vm);
  178. }else{
  179. console.log(res2.msg);
  180. }
  181. }
  182. if(res3){
  183. if(res3.status == 200){
  184. listHandle(res3.data, vm);
  185. }else{
  186. console.log(res3.msg);
  187. }
  188. }
  189. })
  190. }
  191. }
  192. function handleTopPanelData(data, vm){
  193. var obj = data.result[0];
  194. vm.topDatas = {
  195. total: obj.total,
  196. noRelyCount: obj.noRelyCount,
  197. noRelyRate: obj.noRelyRate,
  198. relyRate: obj.relyRate
  199. }
  200. }
  201. function handleSecondPanelData(data, vm){
  202. var list = data.resultList,
  203. xData = [],
  204. yData = [];
  205. for(i=0; i<list.length; i++){
  206. var item = list[i];
  207. xData.push(item.name + "时");
  208. yData.push(item.num);
  209. }
  210. drawBarChart(xData, yData);
  211. }
  212. function listHandle(data, vm){
  213. var list = data.resultList;
  214. var topArr = soreRank(getKeyValueArr(list, 'noRelyDoubleRate'));
  215. var arr = _.map(list, function(o, index){
  216. var cols = [o.name, o.total, o.noRelyCount, o.noRelyRate];
  217. return {
  218. rank: topArr[index],
  219. code: o.code,
  220. name: o.name,
  221. cols: cols
  222. }
  223. });
  224. EventBus.$emit("render-area-data",{
  225. level: vm.level,
  226. area: vm.area,
  227. lowLevel: vm.lowLevel,
  228. headers: ["排名", "咨询数", "未回复数", "未回复率"],
  229. rows: arr
  230. });
  231. }
  232. function drawBarChart(xData, yData) {
  233. var myChart = echarts.init(document.getElementById('barChart'));
  234. var options = {
  235. calculable: true,
  236. tooltip: {
  237. trigger: 'item',
  238. // formatter: '{a}<br />{b} : {c}次'
  239. },
  240. toolbox: {
  241. dataZoom: true,
  242. show: true,
  243. orient: 'vertical',
  244. x: 'right',
  245. y: 'center'
  246. },
  247. grid: {
  248. left: '20px',
  249. right: '20px',
  250. bottom: '20px',
  251. top: '20px',
  252. containLabel: true
  253. },
  254. xAxis: [{
  255. type: 'category',
  256. axisLine: {
  257. show: true,
  258. lineStyle: {
  259. color: '#dcdcdc',
  260. width: 1
  261. }
  262. },
  263. axisLabel: {
  264. show: true,
  265. color: '#666'
  266. },
  267. splitLine: {
  268. show: false
  269. },
  270. data: xData
  271. }],
  272. yAxis: [{
  273. type: 'value',
  274. axisLine: {
  275. show: true,
  276. lineStyle: {
  277. color: '#dcdcdc',
  278. width: 1
  279. }
  280. },
  281. axisLabel: {
  282. show: true,
  283. color: '#666'
  284. },
  285. splitLine: {
  286. show: false
  287. },
  288. }],
  289. series: [{
  290. name: '回复次数',
  291. type: 'bar',
  292. barWidth: 40,
  293. itemStyle: {
  294. normal: {
  295. color: function(params) {
  296. var colorList = ['#12B7F5', '#FB5DAB', '#CD67FD', '#FFC800', '#61EB41'];
  297. return colorList[params.dataIndex]
  298. },
  299. label: {
  300. show: true,
  301. position: 'top',
  302. formatter: function(params) {
  303. return params.value;
  304. }
  305. },
  306. barBorderRadius: 0
  307. }
  308. },
  309. data: yData
  310. }]
  311. };
  312. myChart.clear();
  313. myChart.setOption(options);
  314. window.onresize = function() {
  315. myChart.resize();
  316. }
  317. }