| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 | 
							- (function(){
 
-     Vue.component('table-panel',{
 
-         template: '<div class="table-panel">\
 
-     		<div class="flex table-tab-pane" v-if="!hastopbar">\
 
-     			<div class="f_s_0 c-t-center pt20" style="width:40px;"><img v-show="reqlength&&reqlength>1" @click="back" src="../../../images/fanhui_icon.png" width="18" height="18"></div>\
 
-     			<div class="f_g_1 table-tab-item" v-for="(item,index) in tabList" :key="index" @click="tabClick(index)" v-if="item.isShow">\
 
-     				<div class="plr20" :class="{\'active\':tabActive==index}"><span>{{item.name}}</span></div>\
 
-     			</div>\
 
-     		</div>\
 
-     		<div class="ptb20 plr25">\
 
-     			<table class="table-content table-bordered table-striped mb20" id="listTable" :style="headers[0].tablestyle">\
 
- 	                <thead><tr>\
 
- 	                	<th class="c-t-center" v-if="firstTh" style="width:50px;">{{firstTh}}</th>\
 
- 	                    <th v-for="(th,i) in headers" :key="i" :style="th.style">{{th.thead}}\
 
- 	                    	<el-tooltip class="item" effect="dark" :content="th.tip" placement="top" v-if="th.tip">\
 
- 						      <img class="c-position-a tip" src="../../../images/icon_wenhao2.png" alt="" style="top: 13px;left:70px;">\
 
- 						    </el-tooltip>\
 
- 	                    </th>\
 
- 	                </tr></thead>\
 
- 	                <tbody>\
 
- 	                    <tr v-if="tabledata.length>0" v-for="(row,index) in tabledata" :key="index" class="data-row">\
 
- 	                    	<td class="c-t-center" v-if="firstTh">{{row.rank}}</td>\
 
- 	                        <td v-for="(th,i) in headers" :key="i"  :class="{\'c-t-center\':i>=1,\'tdPointor\':!cantclick}" @click="getLowLevelData(row,th)">\
 
- 		                        {{row[th.param]}}\
 
- 	                        </td>\
 
- 	                    </tr>\
 
- 	                    <tr v-if="tabledata.length==0">\
 
- 	                        <td v-if="firstTh" :colspan="headers.length+1" class="c-t-center">无数据</td>\
 
- 	                        <td v-else :colspan="headers.length" class="c-t-center">无数据</td>\
 
- 	                    </tr>\
 
- 	                </tbody>\
 
- 	            </table>\
 
-     		</div>\
 
-         </div>',
 
-         props:["index","tabledata","cantclick","hastopbar","reqlength"],
 
-         data: function(){
 
-             return {
 
-             	tabList:[{name:"各区",level:"4",lowlevel:"",isShow:true},{name:"社区",level:"3",lowlevel:"2",isShow:true},{name:"团队",level:"2",lowlevel:"1",isShow:true}],
 
-             	tabActive:0,
 
-             	headers:[{thead:"排名",param:"name"},{thead:"名称",param:"name",tip:""},{thead:"",param:"address",tip:""}],
 
-             	firstTh:"排名",
 
- 			}
 
-         },
 
-         mounted: function(){
 
-         	var vm=this
 
-             EventBus.$on("render-table-data", function(arg){
 
-             	vm.firstTh=arg.firstTh||"排名"
 
-             })
 
-         },
 
-         methods: {
 
-         	initTable:function(arg){
 
- 	            var vm = this;
 
- 	            if(arg.tabList&&arg.tabList.length>0){
 
- 	            	vm.tabList=arg.tabList
 
- 	            }
 
- 	            if(arg.headers&&arg.headers.length>0){
 
- 	            	vm.headers=arg.headers
 
- 	            }
 
-             	var showIndex=vm.tabList.length-arg.tabnumber||0  //小于这个值的tab隐藏
 
-     			_.each(vm.tabList,function(item,index){  
 
-     				if(index<showIndex){
 
-     					item.isShow=false
 
-     				}else{
 
-     					item.isShow=true
 
-     				}
 
-     			})
 
- 				vm.tabActive=showIndex				
 
-         		if(!vm.hastopbar){
 
-         			vm.headers[0].thead=vm.tabList[vm.tabActive].name
 
-         		}
 
-         	},
 
-         	tabClick:function(index){
 
-             	var vm = this;
 
-             	if(vm.tabActive != index){
 
- 	        		vm.tabActive = index
 
- 	        		//触发组件监听事件,去父页面请求新的数据
 
- 	                this.$emit("getnewdata", {
 
- 		                lowLevel: vm.tabList[index].lowlevel
 
- 	                });				
 
- 	        		if(!vm.hastopbar){
 
- 	        			vm.headers[0].thead=vm.tabList[vm.tabActive].name
 
- 	        		}
 
-             	}
 
-         	},
 
-             getLowLevelData: function(row,th){
 
-             	var vm=this
 
-             	if(!vm.cantclick||th.canclick){  //点击名称有效
 
- 	            	if(vm.tabActive == vm.tabList.length-1){  
 
- 	            		if(vm.tabList[vm.tabActive].name=="团队"){ //tab在最后一级,显示团队信息
 
- 			                var title="团队信息"
 
- 		                	var size="md"
 
- 		                	var component='team-info'
 
- 		                	if(vm.index==27){
 
- 		                		title="团队信息和代预约记录"
 
- 		                		size="lg"
 
- 		                		component='team-info-dyy'
 
- 		                	}
 
- 		                    //弹框显示团队信息
 
- 		                    Vuedals.Bus.$emit('new', {
 
- 		                        title: title,
 
- 		                        component: component,
 
- 		                        props: {
 
- 		                            teamId: row.code,
 
- 		                            year: vm.year
 
- 		                        },
 
- 		                        size:size
 
- 		                    });
 
- 	            		}
 
- 	            	}else{
 
- 	            		vm.changeTab()
 
- 	            		//触发组件监听事件,去父页面请求新的数据
 
- 	                    this.$emit("getnewdata", {
 
- 	                        level: vm.tabList[vm.tabActive].level,
 
- 	                        area: row.code,
 
- 	                        areaTitle: row.name,
 
- 	                    });
 
- 	            	}
 
-             	}
 
-             },
 
-             changeTab:function(arg){
 
-             	var vm=this
 
-             	var showIndex=0
 
-             	if(arg){  //回退
 
- 	            	vm.tabActive--
 
- 	            	showIndex = _.findIndex(vm.tabList,{level:arg.level.toString()})
 
-             	}else{   //下转
 
-         			vm.tabActive++
 
-             		showIndex = vm.tabActive
 
-             	}
 
-         		_.each(vm.tabList,function(item,index){
 
-     				if(index<showIndex){
 
-     					item.isShow=false
 
-     				}else{
 
-     					item.isShow=true
 
-     				}
 
-     			})
 
-         		if(!vm.hastopbar){
 
-         			vm.headers[0].thead=vm.tabList[vm.tabActive].name
 
-         		}
 
-           },
 
-           back:function(){
 
-           		//触发组件监听事件,去父页面请求新的数据
 
-                 this.$emit("backtobefore");
 
-           },
 
-         }
 
-     });
 
- })()
 
 
  |