354 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			Plaintext
		
	
	
			
		
		
	
	
			354 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			Plaintext
		
	
	
| <template>
 | |
|   <div v-loading="loading" class="resumes-container">
 | |
|     <div class="resume-content">
 | |
|       <p>Resume</p>
 | |
|       <div class="upload-content">
 | |
|         <!-- <upload-files ref="uploadResume" :doctor-id="doctorId" :data-list="resumeList" :language="2" btn-name="Upload(English)" type="Resume" accept=".doc, .docx" @getFileList="getFileList" /> -->
 | |
|         <div class="uploadFile-container">
 | |
|           <el-upload
 | |
|             class="upload-demo"
 | |
|             :data="{language:2}"
 | |
|             action
 | |
|             :show-file-list="false"
 | |
|             :http-request="handleUploadFile"
 | |
|             :file-list="resumeList"
 | |
|             accept=".doc,.docx"
 | |
|           >
 | |
|             <el-button size="small" type="primary" :disabled="isDisabled">Upload</el-button>
 | |
|           </el-upload>
 | |
|         </div>
 | |
|       </div>
 | |
| 
 | |
|       <p>(must be in doc,docx format)</p>
 | |
|     </div>
 | |
|     <div class="resumeTbl">
 | |
|       <el-table :data="resumeListEN" size="small">
 | |
|         <el-table-column type="index" width="40" />
 | |
|         <el-table-column prop="FileName" label="Resume" width="180" show-overflow-tooltip />
 | |
|         <el-table-column prop="CreateTime" label="Upload Time" width="150" show-overflow-tooltip />
 | |
|         <el-table-column
 | |
|           prop="IsOfficial"
 | |
|           label="Official"
 | |
|           width="100"
 | |
|         >
 | |
|           <template slot-scope="scope">
 | |
|             {{ scope.row.IsOfficial === true?'Yes':'No' }}
 | |
|           </template>
 | |
|         </el-table-column>
 | |
|         <el-table-column
 | |
|           prop="Language"
 | |
|           label="Language"
 | |
|           width="100"
 | |
|           show-overflow-tooltip
 | |
|         >
 | |
|           <template slot-scope="scope">
 | |
|             {{ scope.row.Language===1?'中文':'English' }}
 | |
|             <!-- <el-button size="small" type="text" @click="handleLanguageClick(scope.row)">{{ scope.row.Language===1?'CH':scope.row.Language===2?'EN':'Setting' }}</el-button> -->
 | |
|           </template>
 | |
|         </el-table-column>
 | |
|         <el-table-column label="Action" width="400">
 | |
|           <template slot-scope="scope">
 | |
|             <el-button type="text" size="small" @click="handlePreview(scope.row)">Download</el-button>
 | |
|             <el-button type="text" size="small" @click="handleRemoveFile(scope.row)">Delete</el-button>
 | |
|             <el-button
 | |
|               type="text"
 | |
|               size="small"
 | |
|               :disabled="scope.row.IsOfficial"
 | |
|               @click="handleSetOfiical(scope.row)"
 | |
|             >Set as Official</el-button>
 | |
|           </template>
 | |
|         </el-table-column>
 | |
|       </el-table>
 | |
| 
 | |
|     </div>
 | |
|     <div class="resume-content" style="margin-top:10px;">
 | |
|       <p>中文简历</p>
 | |
|       <div class="upload-content">
 | |
|         <div class="uploadFile-container">
 | |
|           <el-upload
 | |
|             :data="{language:1}"
 | |
|             class="upload-demo"
 | |
|             action
 | |
|             :show-file-list="false"
 | |
|             :http-request="handleUploadFile"
 | |
|             :file-list="resumeList"
 | |
|             accept=".doc, .docx"
 | |
|           >
 | |
|             <el-button size="small" type="primary" :disabled="isDisabled">上传</el-button>
 | |
|           </el-upload>
 | |
|         </div>
 | |
|       </div>
 | |
|       <p>(必须是 doc,docx 格式)</p>
 | |
|     </div>
 | |
|     <div class="resumeTbl">
 | |
|       <el-table :data="resumeListCN" size="small">
 | |
|         <el-table-column type="index" width="40" />
 | |
|         <el-table-column prop="FileName" label="Resume" width="180" show-overflow-tooltip />
 | |
|         <el-table-column prop="CreateTime" label="Upload Time" width="150" show-overflow-tooltip />
 | |
|         <el-table-column
 | |
|           prop="IsOfficial"
 | |
|           label="Official"
 | |
|           width="100"
 | |
|         >
 | |
|           <template slot-scope="scope">
 | |
|             {{ scope.row.IsOfficial === true?'Yes':'No' }}
 | |
|           </template>
 | |
|         </el-table-column>
 | |
|         <el-table-column
 | |
|           prop="Language"
 | |
|           label="Language"
 | |
|           width="100"
 | |
|           show-overflow-tooltip
 | |
|         >
 | |
|           <template slot-scope="scope">
 | |
|             {{ scope.row.Language===1?'中文':'English' }}
 | |
|             <!-- <el-button size="small" type="text" @click="handleLanguageClick(scope.row)">{{ scope.row.Language===1?'CH':scope.row.Language===2?'EN':'Setting' }}</el-button> -->
 | |
|           </template>
 | |
|         </el-table-column>
 | |
|         <el-table-column label="Action" width="400">
 | |
|           <template slot-scope="scope">
 | |
|             <el-button type="text" size="small" @click="handlePreview(scope.row)">Download</el-button>
 | |
|             <el-button type="text" size="small" @click="handleRemoveFile(scope.row)">Delete</el-button>
 | |
|             <el-button
 | |
|               type="text"
 | |
|               size="small"
 | |
|               :disabled="scope.row.IsOfficial"
 | |
|               @click="handleSetOfiical(scope.row)"
 | |
|             >Set as Official</el-button>
 | |
|           </template>
 | |
|         </el-table-column>
 | |
|       </el-table>
 | |
|     </div>
 | |
|     <el-dialog
 | |
|       title="Please select the language type of resume first."
 | |
|       :visible.sync="dialogVisible"
 | |
|       width="30%"
 | |
|       size="small"
 | |
|     >
 | |
|       <span>Language: </span>
 | |
|       <el-radio-group v-model="language">
 | |
|         <el-radio :label="2">English</el-radio>
 | |
|         <el-radio :label="1">中文</el-radio>
 | |
|       </el-radio-group>
 | |
|       <span slot="footer" class="dialog-footer">
 | |
|         <el-button size="small" @click="dialogVisible = false">Cancel</el-button>
 | |
|         <el-button type="primary" size="small" @click="setResumeLanguage">Ok</el-button>
 | |
|       </span>
 | |
|     </el-dialog>
 | |
|   </div>
 | |
| </template>
 | |
| <script>
 | |
| import { getAttachmentByType, uploadFile, saveAttachments, deleteAttachment, setOfficial, setLanguageForResume } from '@/api/attachment'
 | |
| export default {
 | |
|   props: {
 | |
|     id: {
 | |
|       type: String,
 | |
|       default() {
 | |
|         return ''
 | |
|       }
 | |
|     }
 | |
|   },
 | |
|   data() {
 | |
|     return {
 | |
|       doctorId: this.$route.query.Id,
 | |
|       resumeList: [],
 | |
|       resumeListEN: [],
 | |
|       resumeListCN: [],
 | |
|       language: 0,
 | |
|       dialogVisible: false,
 | |
|       currentRow: {},
 | |
|       repeat: false,
 | |
|       isDisabled: false,
 | |
|       loading: false
 | |
|     }
 | |
|   },
 | |
|   created() {
 | |
|     this.getResumeList()
 | |
|   },
 | |
|   methods: {
 | |
|     getResumeList() {
 | |
|       this.loading = true
 | |
|       getAttachmentByType(this.doctorId, 'Resume').then(res => {
 | |
|         if (res.IsSuccess) {
 | |
|           if (res.Result.length > 0) {
 | |
|             this.resumeList = res.Result
 | |
|             this.filterByLanguage()
 | |
|           }
 | |
|         }
 | |
|         this.loading = false
 | |
|       }).catch(() => { this.loading = false })
 | |
|     },
 | |
|     handleUploadFile(param) {
 | |
|       this.repeat = false
 | |
|       // const fileName = param.file.name.substring(0, param.file.name.lastIndexOf('.'))
 | |
|       // const extension = param.file.name.substring(param.file.name.lastIndexOf('.'))
 | |
|       // 检测文件后缀名
 | |
|       if (this.checkFileSuffix(param.file.name) > -1) {
 | |
|         // 检测是否有重名文件
 | |
|         const isRepeat = this.resumeList.some(item => item.FileName === param.file.name)
 | |
|         if (isRepeat) {
 | |
|           this.$confirm('Override the existing resume?', {
 | |
|             type: 'warning',
 | |
|             distinguishCancelAndClose: true,
 | |
|             confirmButtonText: 'OK',
 | |
|             cancelButtonText: 'Cancel'
 | |
|           })
 | |
|             .then(() => {
 | |
|               // 重名覆盖
 | |
|               this.repeat = true
 | |
|               this.uploadFile(param.file, param.data.language)
 | |
|             })
 | |
|             .catch(action => {})
 | |
|         } else {
 | |
|           this.uploadFile(param.file, param.data.language)
 | |
|         }
 | |
|       } else {
 | |
|         this.$message.error(`Must be in ${this.accept} format`)
 | |
|       }
 | |
|     },
 | |
|     uploadFile(file, language) {
 | |
|       this.isDisabled = true
 | |
|       var files = this.resumeList
 | |
|       uploadFile(file, 'Resume', this.doctorId).then(res => {
 | |
|         if (this.repeat) {
 | |
|           const index = files.findIndex((item, index) => {
 | |
|             return item.FileName === file.name
 | |
|           })
 | |
|           files[index].Path = res.Result.FilePath
 | |
|           files[index].FullPath = res.Result.FullFilePath
 | |
|           files[index].ReUpload = true
 | |
|           files[index].Language = language
 | |
|         } else {
 | |
|           const fileData = {
 | |
|             DoctorId: this.doctorId,
 | |
|             Type: 'Resume',
 | |
|             Path: res.Result.FilePath,
 | |
|             FullPath: res.Result.FullFilePath,
 | |
|             FileName: file.name,
 | |
|             Language: language
 | |
|           }
 | |
|           files.push(fileData)
 | |
|         }
 | |
|         this.saveUploadFiles(files)
 | |
|       })
 | |
|         .catch(() => {
 | |
|           this.isDisabled = false
 | |
|         })
 | |
|     },
 | |
|     saveUploadFiles(files) {
 | |
|       saveAttachments(files).then(res => {
 | |
|         this.resumeList = res.Result
 | |
|         this.filterByLanguage()
 | |
|         this.isDisabled = false
 | |
|         this.$message.success('Uploaded successfully')
 | |
|       }).catch(() => {
 | |
|         this.isDisabled = false
 | |
|       })
 | |
|     },
 | |
|     filterByLanguage() {
 | |
|       this.resumeListEN = []
 | |
|       this.resumeListCN = []
 | |
|       this.resumeList.map(resume => {
 | |
|         if (resume.Language === 2) {
 | |
|           this.resumeListEN.push(resume)
 | |
|         } else if (resume.Language === 1) {
 | |
|           this.resumeListCN.push(resume)
 | |
|         }
 | |
|       })
 | |
|     },
 | |
|     checkFileSuffix(fileName) {
 | |
|       const accept = '.doc, .docx'
 | |
|       var index = fileName.lastIndexOf('.')
 | |
|       var suffix = fileName.substring(index + 1, fileName.length).toLocaleLowerCase()
 | |
|       return accept.search(suffix)
 | |
|     },
 | |
|     handlePreview(row) {
 | |
|       if (row.FullPath) {
 | |
|         window.open(row.FullPath, '_blank')
 | |
|       }
 | |
|     },
 | |
|     handleRemoveFile(row) {
 | |
|       this.$confirm('Sure to delete?', {
 | |
|         type: 'warning',
 | |
|         distinguishCancelAndClose: true,
 | |
|         confirmButtonText: 'Ok',
 | |
|         cancelButtonText: 'Cancel'
 | |
|       }).then(() => {
 | |
|         deleteAttachment(row.Id, row.Path)
 | |
|           .then(res => {
 | |
|             if (res.IsSuccess) {
 | |
|               this.resumeList.splice(this.resumeList.findIndex(item => item.Id === row.Id), 1)
 | |
|               this.filterByLanguage()
 | |
|               this.$message({
 | |
|                 message: 'Deleted successfully!',
 | |
|                 type: 'success'
 | |
|               })
 | |
|             }
 | |
|           })
 | |
|       })
 | |
|         .catch(action => {})
 | |
|     },
 | |
|     handleSetOfiical(row) {
 | |
|       setOfficial(this.doctorId, row.Id, row.Language).then(res => {
 | |
|         if (res.IsSuccess) {
 | |
|           this.getResumeList()
 | |
|           this.$message({
 | |
|             message: 'Saved successfully!',
 | |
|             type: 'success'
 | |
|           })
 | |
|         }
 | |
|       })
 | |
|     },
 | |
|     handleLanguageClick(row) {
 | |
|       this.dialogVisible = true
 | |
|       this.language = row.Language
 | |
|       this.currentRow = row
 | |
|     },
 | |
|     setResumeLanguage() {
 | |
|       setLanguageForResume(this.doctorId, this.currentRow.Id, this.language).then(res => {
 | |
|         if (res.IsSuccess) {
 | |
|           this.dialogVisible = false
 | |
|           this.getResumeList()
 | |
|           this.$message({
 | |
|             message: 'Saved successfully!',
 | |
|             type: 'success'
 | |
|           })
 | |
|         }
 | |
|       })
 | |
|     }
 | |
|   }
 | |
| }
 | |
| </script>
 | |
| <style lang="scss">
 | |
| .resumes-container{
 | |
|   .resume-content{
 | |
|     p {
 | |
|       float: left;
 | |
|       font-size: 13px;
 | |
|       line-height: 30px;
 | |
|       margin: 0 5px;
 | |
|     }
 | |
|     .uploadFile-container .el-upload--text {
 | |
|       border: none;
 | |
|       // width: 80px;
 | |
|       // height: 30px;
 | |
|     }
 | |
|     .uploadFile-container .el-input--small {
 | |
|       margin-bottom: 5px;
 | |
|     }
 | |
|     .uploadFile-container .el-icon-circle-check {
 | |
|       color: #00d1b2;
 | |
|       font-size: 14px;
 | |
|     }
 | |
|     .upload-content {
 | |
|       float: left;
 | |
|     }
 | |
| 
 | |
|   }
 | |
|   .el-dialog__body{
 | |
|     padding: 10px 20px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| </style>
 |