gamma模块下 analyze korsum弹窗 右侧的table改成可编辑的表格
This commit is contained in:
		
							parent
							
								
									b936995317
								
							
						
					
					
						commit
						4ec2fec97b
					
				
							
								
								
									
										49
									
								
								src/views/spectrumAnalysis/components/Modals/EditCell.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								src/views/spectrumAnalysis/components/Modals/EditCell.vue
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,49 @@ | ||||||
|  | <template> | ||||||
|  |   <div class="editable-cell"> | ||||||
|  |     <div v-if="editable" class="editable-cell-input-wrapper"> | ||||||
|  |       <a-input ref="myInput" :value="value" @change="handleChange" @blur="handleBlur" /> | ||||||
|  |     </div> | ||||||
|  |     <div v-else class="editable-cell-text-wrapper" @dblclick="handleCellClick"> | ||||||
|  |       {{ value || ' ' }} | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | export default { | ||||||
|  |   props: { | ||||||
|  |     text: Number, | ||||||
|  |   }, | ||||||
|  |   data() { | ||||||
|  |     return { | ||||||
|  |       value: this.text, | ||||||
|  |       editable: false, | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     handleCellClick() { | ||||||
|  |       this.editable = true | ||||||
|  |       this.$nextTick(() => { | ||||||
|  |         this.$refs.myInput.focus() | ||||||
|  |       }) | ||||||
|  |     }, | ||||||
|  |     handleChange(e) { | ||||||
|  |       this.value = e.target.value | ||||||
|  |     }, | ||||||
|  |     handleBlur() { | ||||||
|  |       this.editable = false | ||||||
|  |       this.$emit('change', this.value) | ||||||
|  |     }, | ||||||
|  |   }, | ||||||
|  | } | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <style lang="less" scoped> | ||||||
|  | /deep/.ant-input { | ||||||
|  |   padding: 0; | ||||||
|  | } | ||||||
|  | .editable-cell-text-wrapper { | ||||||
|  |   min-height: 32px; | ||||||
|  |   line-height: 32px; | ||||||
|  | } | ||||||
|  | </style> | ||||||
|  | @ -10,8 +10,8 @@ | ||||||
|               class="korsum-input-formula" |               class="korsum-input-formula" | ||||||
|               :labelCol="{ |               :labelCol="{ | ||||||
|                 style: { |                 style: { | ||||||
|                   width: '110px' |                   width: '110px', | ||||||
|                 } |                 }, | ||||||
|               }" |               }" | ||||||
|             > |             > | ||||||
|               <a-form-model-item label="Total Effi = exp("> |               <a-form-model-item label="Total Effi = exp("> | ||||||
|  | @ -64,9 +64,7 @@ | ||||||
|             <!-- 公式结束 --> |             <!-- 公式结束 --> | ||||||
| 
 | 
 | ||||||
|             <!-- 标题 --> |             <!-- 标题 --> | ||||||
|             <a-button type="primary" class="korsum-input-title" @click="handleInput"> |             <a-button type="primary" class="korsum-input-title" @click="handleInput"> Input </a-button> | ||||||
|               Input |  | ||||||
|             </a-button> |  | ||||||
|             <!-- 标题结束 --> |             <!-- 标题结束 --> | ||||||
| 
 | 
 | ||||||
|             <!-- 表格开始 --> |             <!-- 表格开始 --> | ||||||
|  | @ -125,7 +123,15 @@ | ||||||
|                 :class="outputTableList.length ? 'has-data' : ''" |                 :class="outputTableList.length ? 'has-data' : ''" | ||||||
|                 :scroll="{ y: 584 }" |                 :scroll="{ y: 584 }" | ||||||
|                 :pagination="false" |                 :pagination="false" | ||||||
|               ></a-table> |               > | ||||||
|  |                 <template v-for="(col, i) in outputColumns" :slot="col.dataIndex" slot-scope="text, record, index"> | ||||||
|  |                   <edit-cell | ||||||
|  |                     :text="parseFloat(Number(text).toPrecision(6))" | ||||||
|  |                     :key="i" | ||||||
|  |                     @change="onCellChange(index, col.dataIndex, $event)" | ||||||
|  |                   /> | ||||||
|  |                 </template> | ||||||
|  |               </a-table> | ||||||
|             </div> |             </div> | ||||||
| 
 | 
 | ||||||
|             <div class="korsum-output-operation"> |             <div class="korsum-output-operation"> | ||||||
|  | @ -148,58 +154,62 @@ | ||||||
| import ModalMixin from '@/mixins/ModalMixin' | import ModalMixin from '@/mixins/ModalMixin' | ||||||
| import TitleOverBorder from '../TitleOverBorder.vue' | import TitleOverBorder from '../TitleOverBorder.vue' | ||||||
| import { getAction, postAction } from '@/api/manage' | import { getAction, postAction } from '@/api/manage' | ||||||
| import * as XLSX from 'xlsx'; | import * as XLSX from 'xlsx' | ||||||
|  | import EditCell from './EditCell.vue' | ||||||
| 
 | 
 | ||||||
| const columns = [ | const columns = [ | ||||||
|   { |   { | ||||||
|     title: 'Energy', |     title: 'Energy', | ||||||
|     dataIndex: 'energy', |     dataIndex: 'energy', | ||||||
|     scopedSlots: { |     scopedSlots: { | ||||||
|       customRender: 'energy' |       customRender: 'energy', | ||||||
|     } |     }, | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     title: 'Total Efficiency', |     title: 'Total Efficiency', | ||||||
|     dataIndex: 'totalEffi', |     dataIndex: 'totalEffi', | ||||||
|     scopedSlots: { |     scopedSlots: { | ||||||
|       customRender: 'totalEffi' |       customRender: 'totalEffi', | ||||||
|     } |     }, | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     title: 'Peak Efficiency', |     title: 'Peak Efficiency', | ||||||
|     dataIndex: 'peakEffi', |     dataIndex: 'peakEffi', | ||||||
|     scopedSlots: { |     scopedSlots: { | ||||||
|       customRender: 'peakEffi' |       customRender: 'peakEffi', | ||||||
|     } |     }, | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     title: 'Uncertainty(%)', |     title: 'Uncertainty(%)', | ||||||
|     dataIndex: 'uncertain', |     dataIndex: 'uncertain', | ||||||
|     scopedSlots: { |     scopedSlots: { | ||||||
|       customRender: 'uncertain' |       customRender: 'uncertain', | ||||||
|     } |     }, | ||||||
|   } |   }, | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| const outputColumns = [ | const outputColumns = [ | ||||||
|   { |   { | ||||||
|     title: 'Energy', |     title: 'Energy', | ||||||
|     dataIndex: 'energy', |     dataIndex: 'energy', | ||||||
|     customRender: (text) =>  parseFloat(Number(text).toPrecision(6)) |     scopedSlots: { customRender: 'energy' }, | ||||||
|  |     // customRender: (text) =>  parseFloat(Number(text).toPrecision(6)) | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     title: 'Correct Factor', |     title: 'Correct Factor', | ||||||
|     dataIndex: 'correctFactor', |     dataIndex: 'correctFactor', | ||||||
|     customRender: (text) =>  parseFloat(Number(text).toPrecision(6)) |     scopedSlots: { customRender: 'correctFactor' }, | ||||||
|  |     // customRender: (text) => parseFloat(Number(text).toPrecision(6)), | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     title: 'Uncertainty(%)', |     title: 'Uncertainty(%)', | ||||||
|     dataIndex: 'uncertainty', |     dataIndex: 'uncertainty', | ||||||
|     customRender: (text) =>  parseFloat(Number(text).toPrecision(6)) |     scopedSlots: { customRender: 'uncertainty' }, | ||||||
|   } |     // customRender: (text) => parseFloat(Number(text).toPrecision(6)), | ||||||
|  |   }, | ||||||
| ] | ] | ||||||
| export default { | export default { | ||||||
|   components: { TitleOverBorder }, |   components: { TitleOverBorder, EditCell }, | ||||||
|   mixins: [ModalMixin], |   mixins: [ModalMixin], | ||||||
|   data() { |   data() { | ||||||
|     this.columns = columns |     this.columns = columns | ||||||
|  | @ -217,7 +227,7 @@ export default { | ||||||
|       filterWord: '', // 筛选 |       filterWord: '', // 筛选 | ||||||
| 
 | 
 | ||||||
|       fileName: '', // save excel name |       fileName: '', // save excel name | ||||||
|       analyseData: {} // 分析结果 |       analyseData: {}, // 分析结果 | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
|   methods: { |   methods: { | ||||||
|  | @ -245,7 +255,7 @@ export default { | ||||||
|         totalEf3: 0.111096, |         totalEf3: 0.111096, | ||||||
|         totalEf4: -0.003896, |         totalEf4: -0.003896, | ||||||
|         totalEf5: -0.000345, |         totalEf5: -0.000345, | ||||||
|         totalEf6: 0.000017 |         totalEf6: 0.000017, | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       this.efficiency = { |       this.efficiency = { | ||||||
|  | @ -254,7 +264,7 @@ export default { | ||||||
|         effciency3: 0.583265, |         effciency3: 0.583265, | ||||||
|         effciency4: -0.065884, |         effciency4: -0.065884, | ||||||
|         effciency5: 0.003255, |         effciency5: 0.003255, | ||||||
|         effciency6: -0.000059 |         effciency6: -0.000059, | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       this.getInfo() |       this.getInfo() | ||||||
|  | @ -269,9 +279,9 @@ export default { | ||||||
|         const { success, result, message } = await postAction('/gamma/KorSumInput', { |         const { success, result, message } = await postAction('/gamma/KorSumInput', { | ||||||
|           ...this.totalEffi, |           ...this.totalEffi, | ||||||
|           ...this.efficiency, |           ...this.efficiency, | ||||||
|           energys: this.list.map(item => item.energy) |           energys: this.list.map((item) => item.energy), | ||||||
|         }) |         }) | ||||||
|         console.log(success); |         console.log(success) | ||||||
|         if (success) { |         if (success) { | ||||||
|           this.list = result |           this.list = result | ||||||
|         } else { |         } else { | ||||||
|  | @ -291,12 +301,12 @@ export default { | ||||||
|         this.isLoading = false |         this.isLoading = false | ||||||
|         if (success) { |         if (success) { | ||||||
|           this.analyseData = result |           this.analyseData = result | ||||||
|           console.log(result); |           console.log(result) | ||||||
|         } else { |         } else { | ||||||
|           this.$message.error(message) |           this.$message.error(message) | ||||||
|         } |         } | ||||||
|       } catch (error) { |       } catch (error) { | ||||||
|         this.isLoading = false; |         this.isLoading = false | ||||||
|         console.error(error) |         console.error(error) | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|  | @ -308,32 +318,43 @@ export default { | ||||||
| 
 | 
 | ||||||
|     // output栏点击左侧列表 |     // output栏点击左侧列表 | ||||||
|     handleOutputItemClick(item) { |     handleOutputItemClick(item) { | ||||||
|       if(!this.analyseData) { |       if (!this.analyseData) { | ||||||
|         this.$message.error("Analyse Fail!") |         this.$message.error('Analyse Fail!') | ||||||
|         return false; |         return false | ||||||
|       } |       } | ||||||
|       this.selectedItem = item |       this.selectedItem = item | ||||||
|       this.outputTableList = []; |       this.outputTableList = [] | ||||||
| 
 | 
 | ||||||
|       // 根据核素名获取结果集 |       // 根据核素名获取结果集 | ||||||
|       let data = this.analyseData[this.selectedItem] |       let data = this.analyseData[this.selectedItem] | ||||||
|       if(!data || data.energy.length < 1) { |       if (!data || data.energy.length < 1) { | ||||||
|         this.$message.error("Analyse Fail!") |         this.$message.error('Analyse Fail!') | ||||||
|         return false; |         return false | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       let result = []; |       let result = [] | ||||||
|       for(let i = 0; i < data.energy.length; i++ ) { |       for (let i = 0; i < data.energy.length; i++) { | ||||||
|         // 将数据进行填充并 |         // 将数据进行填充并 | ||||||
|         let obj = { |         let obj = { | ||||||
|           "energy": data.energy[i], |           energy: data.energy[i], | ||||||
|           "correctFactor" : data.factor[i], |           correctFactor: data.factor[i], | ||||||
|           "uncertainty" : (data.factor[i] - 1) / 10 * 100 |           uncertainty: ((data.factor[i] - 1) / 10) * 100, | ||||||
|         } |         } | ||||||
|         result.push(obj); |         result.push(obj) | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       this.outputTableList = result; |       this.outputTableList = result | ||||||
|  |     }, | ||||||
|  |     onCellChange(idx, label, value) { | ||||||
|  |       console.log(this.outputTableList) | ||||||
|  |       console.log(value) | ||||||
|  |       const dataSource = [...this.outputTableList] | ||||||
|  |       const target = dataSource.find((item, index) => index == idx) | ||||||
|  |       if (target) { | ||||||
|  |         target[label] = value | ||||||
|  |         this.outputTableList = dataSource | ||||||
|  |       } | ||||||
|  |       console.log(this.outputTableList) | ||||||
|     }, |     }, | ||||||
| 
 | 
 | ||||||
|     // 导出到excel |     // 导出到excel | ||||||
|  | @ -351,30 +372,30 @@ export default { | ||||||
|           console.log('Cancel') |           console.log('Cancel') | ||||||
|         }, |         }, | ||||||
|         onCancel() { |         onCancel() { | ||||||
|             console.log(_this.fileName); |           console.log(_this.fileName) | ||||||
|           if (_this.fileName) { |           if (_this.fileName) { | ||||||
|             // saveAs(blob, `${_this.fileName}`) |             // saveAs(blob, `${_this.fileName}`) | ||||||
|             // 创建工作簿 |             // 创建工作簿 | ||||||
|               const workbook = XLSX.utils.book_new(); |             const workbook = XLSX.utils.book_new() | ||||||
| 
 | 
 | ||||||
|             // 创建工作表 |             // 创建工作表 | ||||||
|               const worksheet = XLSX.utils.json_to_sheet(_this.outputTableList); |             const worksheet = XLSX.utils.json_to_sheet(_this.outputTableList) | ||||||
| 
 | 
 | ||||||
|             // 将工作表添加到工作簿 |             // 将工作表添加到工作簿 | ||||||
|               XLSX.utils.book_append_sheet(workbook, worksheet, 'Sheet1'); |             XLSX.utils.book_append_sheet(workbook, worksheet, 'Sheet1') | ||||||
| 
 | 
 | ||||||
|             // 导出Excel文件 |             // 导出Excel文件 | ||||||
|               XLSX.writeFile(workbook, _this.fileName + ".xlsx"); |             XLSX.writeFile(workbook, _this.fileName + '.xlsx') | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|       }) |       }) | ||||||
|     } |     }, | ||||||
|   }, |   }, | ||||||
|   computed: { |   computed: { | ||||||
|     outputList() { |     outputList() { | ||||||
|       return this.nuclideList.filter(item => item.toLowerCase().includes(this.filterWord.toLowerCase())) |       return this.nuclideList.filter((item) => item.toLowerCase().includes(this.filterWord.toLowerCase())) | ||||||
|     } |     }, | ||||||
|   } |   }, | ||||||
| } | } | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 任珮宇
						任珮宇