| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337 | 
							- var reqList = [];
 
- new Vue({
 
-     el: "#main",
 
-     data: {
 
-         appname: "咨询分析",
 
-         isback: true,
 
-         isrefresh: true,
 
-         isfilter: true,
 
-         isopen: true,
 
-         //页面请求参数
 
-         level: '',
 
-         area: '',
 
-         areaTitle: '',
 
-         lowLevel: '',
 
-         chooseYear: '',
 
-         endDate: '',
 
-         topDatas: {
 
-             total: 0,
 
-             noRelyCount: 0,
 
-             noRelyRate: 0,
 
-             relyRate: 0
 
-         }
 
-     },
 
-     components: {
 
-         vuedals: Vuedals.Component
 
-     },
 
-     methods:{
 
-         getAreaData: function(arg){
 
-             //如果level改变,则需要重新加载整个页面的数据,否则只需加载底部区域数据
 
-             if(arg.level == this.level){
 
-                 this.lowLevel = arg.lowLevel;
 
-                 loadData([2], this);
 
-             }else{
 
-                 this.level = arg.level;
 
-                 this.lowLevel = arg.lowLevel;
 
-                 this.area = arg.area;
 
-                 this.areaTitle = arg.areaTitle;
 
-                 loadData([0,1,2], this);
 
-             }
 
-             EventBus.$emit('update-area-name', {areaName: this.areaTitle});
 
-             //存储请求所带的参数
 
-             reqList.push({
 
-                 level: this.level,
 
-                 area: this.area,
 
-                 areaTitle: this.areaTitle,
 
-                 lowLevel: this.lowLevel,
 
-                 endDate: this.endDate
 
-             })
 
-         }
 
-     },
 
-     mounted: function(){
 
-         //初始化数据
 
-         initData(this);
 
-         
 
-         //获得顶部各tab的值
 
-         loadData([0,1,2], this); //参数组数表示请求的区域为上中下
 
-         
 
-         //存储请求所带的参数
 
-         reqList.push({
 
-             level: this.level,
 
-             area: this.area,
 
-             areaTitle: this.areaTitle,
 
-             index: this.index,
 
-             endDate: this.endDate,
 
-             startDate: this.startDate,
 
-             lowLevel: this.lowLevel
 
-         });
 
-         
 
-         //设置监听器, 监听折线图日期变化
 
-         var vm = this;
 
-         //监听后退按钮的操作
 
-         EventBus.$on("back-click", function(arg){
 
-             EventBus.$emit('update-statistics-time', {}); //更新统计时间
 
-             if(reqList.length == 1){
 
-                 history.go(-1);
 
-             } 
 
-             else{
 
-                 var preInfo = reqList.pop();
 
-                 var info = reqList[reqList.length - 1];
 
-                 vm.level = info.level;
 
-                 vm.area = info.area;
 
-                 vm.areaTitle = info.areaTitle;
 
-                 vm.lowLevel = info.lowLevel;
 
-                 vm.index = info.index;
 
-                 
 
-                 loadData([0,1,2], vm);
 
-                 EventBus.$emit('update-area-name', {areaName: vm.areaTitle});
 
-             }
 
-         });
 
-         //监听页面刷新
 
-         EventBus.$on("refresh-click", function(arg){
 
-             loadData([0,1,2], vm);
 
-         });
 
-         //弹出筛选框
 
-         EventBus.$on('filter-click', function(arg) {
 
-             //弹框显示筛选条件
 
-             Vuedals.Bus.$emit('new', {
 
-                 title: '条件筛选',
 
-                 onClose:function(data){
 
-                     console.log(data);
 
-                     vm.chooseYear = data.chooseYear;
 
-                     vm.endDate = getEndDate(vm.chooseYear);
 
-                     
 
-                     loadData([0, 1, 2], vm);//刷新数据
 
-                     EventBus.$emit('update-statistics-year', {selectDate: vm.chooseYear + "年"});//更新年份
 
-                     EventBus.$emit('update-statistics-time', {});//更新统计时间
 
-                 },
 
-                 component: 'year-filter',
 
-                 props: {
 
-                     selectedYear: vm.chooseYear
 
-                 }
 
-             });
 
-         });
 
-         $("#main").removeClass("c-hide");
 
-     }
 
- });
 
- function initData(vm){
 
-     //获得缓存中缓存的角色权限
 
-     var userRole = window.sessionStorage.getItem("selectedRole");
 
-     if(!userRole){
 
-         return false;
 
-     }
 
-     vm.userRole = JSON.parse(userRole);
 
-     vm.level = vm.userRole.code == '350200' ? 4 : vm.userRole.code.length == 6 ? 3 : 2;
 
-     vm.area = vm.userRole.code;
 
-     vm.areaTitle = vm.userRole.name;
 
-     EventBus.$emit('update-area-name', {areaName: vm.areaTitle});
 
-     
 
-     var now = new Date();
 
-     if(now.getMonth() >= 6){
 
-         vm.chooseYear = now.getFullYear();
 
-     }else{
 
-         vm.chooseYear = now.getFullYear() - 1;
 
-     }
 
-     vm.endDate = getEndDate(vm.chooseYear);
 
-     EventBus.$emit('update-statistics-year', {selectDate: vm.chooseYear + "年"});
 
- }
 
- function initReqParams(vm){
 
-     var param = [{
 
-         url: "/statistics/Consulting_Title",
 
-         data: {level: vm.level, area: vm.area, year: vm.chooseYear}
 
-     },{
 
-         url: "/statistics/getCoutListByTime",
 
-         data: {level: vm.level, area: vm.area, year: vm.chooseYear}
 
-     },{
 
-         url: "/statistics/Consulting_StatList",
 
-         data: {level: vm.level, area: vm.area, year: vm.chooseYear, sort: 1, date: vm.endDate, lowlevel: vm.lowLevel}
 
-     }];
 
-     
 
-     return param;
 
- }
 
- function loadData(loadArr, vm){
 
-     //获取其他请求的参数
 
-     var reqParams = initReqParams(vm),
 
-         reqPromise = [];
 
-     
 
-     for(i=0; i< loadArr.length; i++){
 
-         var j = loadArr[i];
 
-         var param = reqParams[j];
 
-         reqPromise.push(httpRequest.get(param.url, {data: param.data}));
 
-     }
 
-         
 
-     if(reqPromise.length > 0){
 
-         Promise.all(reqPromise).then(function(ress){
 
-             var res1, res2, res2;
 
-             for(var i=0; i<loadArr.length; i++){
 
-                 var j = loadArr[i] + 1;
 
-                 if(j == 1){
 
-                     res1 = ress[i];
 
-                 }
 
-                 if(j == 2){
 
-                     res2 = ress[i];
 
-                 }
 
-                 if(j == 3){
 
-                     res3 = ress[i];
 
-                 }
 
-                 
 
-             }
 
-             if(res1){
 
-                 if(res1.status == 200){
 
-                     handleTopPanelData(res1.data, vm);
 
-                 }else{
 
-                     console.log(res1.msg);
 
-                 }
 
-             }
 
-             if(res2){
 
-                 if(res2.status == 200){
 
-                     handleSecondPanelData(res2.data, vm);
 
-                 }else{
 
-                    console.log(res2.msg);
 
-                 }
 
-                 
 
-             }
 
-             if(res3){
 
-                 if(res3.status == 200){
 
-                     listHandle(res3.data, vm);
 
-                 }else{
 
-                     console.log(res3.msg);
 
-                 }
 
-             }
 
-         })
 
-     }
 
- }
 
- function handleTopPanelData(data, vm){
 
-     var obj = data.result[0];
 
-     vm.topDatas = {
 
-         total: obj.total,
 
-         noRelyCount: obj.noRelyCount,
 
-         noRelyRate: obj.noRelyRate,
 
-         relyRate: obj.relyRate
 
-     }
 
- }
 
- function handleSecondPanelData(data, vm){
 
-     var list = data.resultList,
 
-         xData = [],
 
-         yData = [];
 
-     for(i=0; i<list.length; i++){
 
-         var item = list[i];
 
-         xData.push(item.name + "时");
 
-         yData.push(item.num);
 
-     }
 
-     drawBarChart(xData, yData);
 
- }
 
- function listHandle(data, vm){
 
-     var list = data.resultList;
 
-     var topArr = soreRank(getKeyValueArr(list, 'noRelyDoubleRate'));
 
-     var arr = _.map(list, function(o, index){
 
-         var cols = [o.name, o.total, o.noRelyCount, o.noRelyRate];
 
-         return {
 
-             rank: topArr[index],
 
-             code: o.code,
 
-             name: o.name,
 
-             cols: cols
 
-         }
 
-     });
 
-     
 
-     EventBus.$emit("render-area-data",{
 
-         level: vm.level,
 
-         area: vm.area,
 
-         lowLevel: vm.lowLevel,
 
-         headers: ["排名", "咨询数", "未回复数", "未回复率"],
 
-         rows: arr
 
-     });
 
- }
 
- function drawBarChart(xData, yData) {
 
-     var myChart = echarts.init(document.getElementById('barChart'));
 
-     var options = {
 
-         calculable: true,
 
-         tooltip: {
 
-             trigger: 'item',
 
- //          formatter: '{a}<br />{b} : {c}次'
 
-         },
 
-         toolbox: {
 
-             dataZoom: true,
 
-             show: true,
 
-             orient: 'vertical',
 
-             x: 'right',
 
-             y: 'center'
 
-         },
 
-         grid: {
 
-             left: '20px',
 
-             right: '20px',
 
-             bottom: '20px',
 
-             top: '20px',
 
-             containLabel: true
 
-         },
 
-         xAxis: [{
 
-             type: 'category',
 
-             axisLine: {
 
-                 show: true,
 
-                 lineStyle: {
 
-                     color: '#dcdcdc',
 
-                     width: 1
 
-                 }
 
-             },
 
-             axisLabel: {
 
-                 show: true,
 
-                 color: '#666'
 
-             },
 
-             splitLine: {
 
-                 show: false
 
-             },
 
-             data: xData
 
-         }],
 
-         yAxis: [{
 
-             type: 'value',
 
-             axisLine: {
 
-                 show: true,
 
-                 lineStyle: {
 
-                     color: '#dcdcdc',
 
-                     width: 1
 
-                 }
 
-             },
 
-             axisLabel: {
 
-                 show: true,
 
-                 color: '#666'
 
-             },
 
-             splitLine: {
 
-                 show: false
 
-             },
 
-         }],
 
-         series: [{
 
-             name: '回复次数',
 
-             type: 'bar',
 
-             barWidth: 40,
 
-             itemStyle: {
 
-                 normal: {
 
-                     color: function(params) {
 
-                         var colorList = ['#12B7F5', '#FB5DAB', '#CD67FD', '#FFC800', '#61EB41'];
 
-                         return colorList[params.dataIndex]
 
-                     },
 
-                     label: {
 
-                         show: true,
 
-                         position: 'top',
 
-                         formatter: function(params) {
 
-                             return params.value;
 
-                         }
 
-                     },
 
-                     barBorderRadius: 0
 
-                 }
 
-             },
 
-             data: yData
 
-         }]
 
-     };
 
-     myChart.clear();
 
-     myChart.setOption(options);
 
-     window.onresize = function() {
 
-         myChart.resize();
 
-     }
 
- }
 
 
  |