152 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
			
		
		
	
	
			152 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
| <template>
 | |
|   <div class="app-container enrollment-stats data-list">
 | |
|     <div class="filter-container">
 | |
|       <el-select v-model="type" size="small" class="mr" @change="handleTypeChange">
 | |
|         <el-option v-for="item in types" :key="item" :label="item" :value="item" />
 | |
|       </el-select>
 | |
|       <el-select v-show="type=='Trial'" ref="croSelection" v-model="listQuery.CroId" size="small" placeholder="CRO" clearable class="mr">
 | |
|         <el-option v-for="item of croList" :key="item.Id" :label="item.CROName" :value="item.Id" />
 | |
|       </el-select>
 | |
|       <el-input v-show="type=='Trial'" v-model="listQuery.TrialCode" style="width:160px" size="small" placeholder="Trial ID" clearable class="mr" />
 | |
|       <el-input v-show="type=='Trial'" v-model="listQuery.Indication" style="width:160px" size="small" placeholder="Indication" clearable class="mr" />
 | |
| 
 | |
|       <el-select
 | |
|         v-show="type=='Reviewer'"
 | |
|         v-model="listQuery.HospitalId"
 | |
|         placeholder="Hospital"
 | |
|         style="width:160px"
 | |
|         size="small"
 | |
|         clearable
 | |
|       >
 | |
|         <el-option
 | |
|           v-for="(item,index) in hospitalList"
 | |
|           :key="index"
 | |
|           :label="item.HospitalName"
 | |
|           :value="item.Id"
 | |
|         />
 | |
|       </el-select>
 | |
|       <el-input v-show="type=='Reviewer'" v-model="listQuery.Reviewer" style="width:160px" size="small" placeholder="Reviewer ID" clearable class="mr" />
 | |
|       <el-date-picker
 | |
|         v-model="listQuery.BeginDate"
 | |
|         size="small"
 | |
|         placeholder="Beginning Month"
 | |
|         value-format="yyyy-MM"
 | |
|         format="yyyy-MM"
 | |
|         type="month"
 | |
|         style="width:160px;margin-right:5px"
 | |
|         :picker-options="beginPickerOption"
 | |
|         :clearable="false"
 | |
|       />To
 | |
|       <el-date-picker
 | |
|         v-model="listQuery.EndDate"
 | |
|         size="small"
 | |
|         placeholder="End Month"
 | |
|         value-format="yyyy-MM"
 | |
|         format="yyyy-MM"
 | |
|         type="month"
 | |
|         style="width:160px;margin:0 5px"
 | |
|         :picker-options="endpickerOption"
 | |
|         :clearable="false"
 | |
|       />
 | |
|       <el-button type="text" size="small" @click="handleReset">Reset</el-button>
 | |
|       <el-button type="primary" size="small" @click="handleSearch">Search</el-button>
 | |
|       <el-button type="primary" size="small" :disabled="exportDisabled" @click="handleExport">Export Excel</el-button>
 | |
|     </div>
 | |
|     <div ref="listContainer" class="data-table clearfix">
 | |
|       <by-reviewer v-if="type=='Reviewer'" ref="Reviewer" :param="listQuery" @selectMore="selectMore" />
 | |
|       <by-trial v-if="type=='Trial'" ref="Trial" :param="listQuery" @selectMore="selectMore" />
 | |
|     </div>
 | |
|   </div>
 | |
| </template>
 | |
| <script>
 | |
| import ByReviewer from './ByReviewer'
 | |
| import ByTrial from './ByTrial'
 | |
| // eslint-disable-next-line no-unused-vars
 | |
| import { FormatTime } from '@/utils/formatter'
 | |
| import store from '@/store'
 | |
| import { mapGetters } from 'vuex'
 | |
| export default {
 | |
|   components: { ByReviewer, ByTrial },
 | |
|   data() {
 | |
|     return {
 | |
|       listQuery: { HospitalId: '', Reviewer: '', CroId: '', TrialCode: '', Indication: '', BeginDate: new Date(new Date().setMonth(new Date().getMonth() - 5)).format('yyyy-MM'), EndDate: new Date().format('yyyy-MM') },
 | |
|       types: ['Reviewer', 'Trial'],
 | |
|       type: 'Reviewer',
 | |
|       exportDisabled: true,
 | |
|       beginPickerOption: {
 | |
|         disabledDate: time => {
 | |
|           if (this.listQuery.EndDate) {
 | |
|             return time.getTime() > new Date(this.listQuery.EndDate).getTime()
 | |
|           } else {
 | |
|             return time.getTime() > Date.now()
 | |
|           }
 | |
|         }
 | |
|       },
 | |
|       endpickerOption: {
 | |
|         disabledDate: time => {
 | |
|           if (this.listQuery.BeginDate) {
 | |
|             return time.getTime() > Date.now() || time.getTime() <= new Date(this.listQuery.BeginDate).getTime()
 | |
|           } else {
 | |
|             return time.getTime() > Date.now()
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   },
 | |
|   computed: {
 | |
|     ...mapGetters(['croList', 'hospitalList'])
 | |
|   },
 | |
|   created() {
 | |
|     store.dispatch('global/getCROList')
 | |
|     store.dispatch('global/getHospital')
 | |
|   },
 | |
|   methods: {
 | |
|     handleSearch() {
 | |
|       this.$refs[this.type].getList()
 | |
|     },
 | |
|     handleReset() {
 | |
|       this.listQuery.HospitalId = ''
 | |
|       this.listQuery.Reviewer = ''
 | |
|       this.listQuery.CroId = ''
 | |
|       this.listQuery.TrialCode = ''
 | |
|       this.listQuery.Indication = ''
 | |
|       this.listQuery.EndDate = new Date().format('yyyy-MM')
 | |
|       this.listQuery.BeginDate = new Date(new Date().setMonth(new Date().getMonth() - 5)).format('yyyy-MM')
 | |
|       this.$refs[this.type].resetList()
 | |
|     },
 | |
|     handleTypeChange() {
 | |
|       this.exportDisabled = true
 | |
|       this.listQuery.HospitalId = ''
 | |
|       this.listQuery.Reviewer = ''
 | |
|       this.listQuery.CroId = ''
 | |
|       this.listQuery.TrialCode = ''
 | |
|       this.listQuery.Indication = ''
 | |
|       this.listQuery.EndDate = new Date().format('yyyy-MM')
 | |
|       this.listQuery.BeginDate = new Date(new Date().setMonth(new Date().getMonth() - 5)).format('yyyy-MM')
 | |
|     },
 | |
|     handleExport() {
 | |
|       this.$refs[this.type].export()
 | |
|     },
 | |
|     selectMore(val) {
 | |
|       this.exportDisabled = val
 | |
|     }
 | |
|   }
 | |
| }
 | |
| </script>
 | |
| <style lang="scss" scoped>
 | |
| .app-container{
 | |
|   padding: 0 10px;
 | |
| }
 | |
| .enrollment-stats{
 | |
|   height: 100%;
 | |
|   .mr{
 | |
|     width: 160px;
 | |
|     margin-right: 5px;
 | |
|   }
 | |
|   .list-container{
 | |
|     margin-top: 10px;
 | |
|     height: calc(100% - 100px);
 | |
|   }
 | |
| }
 | |
| </style>
 |