| | |
| | | <el-tag |
| | | :type="scope.row.result === '阴性' ? 'success' : 'danger'" |
| | | effect="plain" |
| | | @click="handleResultClick(scope.row)" |
| | | style="cursor: pointer;" |
| | | > |
| | | {{ scope.row.result }} |
| | | <i |
| | | v-if=" |
| | | scope.row.result === '阳性' && scope.row.positiveDetails |
| | | " |
| | | class="el-icon-info" |
| | | style="margin-left: 4px;" |
| | | ></i> |
| | | </el-tag> |
| | | </template> |
| | | </el-table-column> |
| | |
| | | v-model="cultureForm.result" |
| | | placeholder="请选择培养结果" |
| | | style="width: 100%" |
| | | @change="handleResultChange" |
| | | > |
| | | <el-option label="阴性" value="阴性" /> |
| | | <el-option label="阳性" value="阳性" /> |
| | |
| | | </el-form-item> |
| | | </el-col> |
| | | </el-row> |
| | | |
| | | <el-form-item |
| | | v-if="cultureForm.result === '阳性'" |
| | | label="阳性详情" |
| | | prop="positiveDetails" |
| | | > |
| | | <el-input |
| | | type="textarea" |
| | | :rows="2" |
| | | v-model="cultureForm.positiveDetails" |
| | | placeholder="请输入阳性结果的详细信息" |
| | | clearable |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="附件"> |
| | | <UploadAttachment |
| | | ref="cultureUploadAttachment" |
| | |
| | | cultureType: "", |
| | | sampleTime: "", |
| | | result: "阴性", |
| | | positiveDetails: "", // 新增:阳性详情 |
| | | attachments: [] |
| | | }, |
| | | cultureFileList: [], |
| | |
| | | ], |
| | | result: [ |
| | | { required: true, message: "请选择培养结果", trigger: "change" } |
| | | ] |
| | | ], |
| | | positiveDetails: [] // 动态验证规则 |
| | | }, |
| | | cultureTypeOptions: [ |
| | | { value: "1", label: "血培养" }, |
| | |
| | | this.recordLoading = false; |
| | | } |
| | | }, |
| | | // 处理培养结果选择变化 |
| | | handleResultChange(value) { |
| | | this.$nextTick(() => { |
| | | if (value === "阳性") { |
| | | this.cultureRules.positiveDetails = [ |
| | | { required: true, message: "请输入阳性详情", trigger: "blur" } |
| | | ]; |
| | | } else { |
| | | this.cultureRules.positiveDetails = []; |
| | | this.cultureForm.positiveDetails = ""; |
| | | } |
| | | // 清除验证 |
| | | if (this.$refs.cultureForm) { |
| | | this.$refs.cultureForm.clearValidate("positiveDetails"); |
| | | } |
| | | }); |
| | | }, |
| | | |
| | | // 处理点击培养结果标签 |
| | | handleResultClick(row) { |
| | | if (row.result === "阳性" && row.positiveDetails) { |
| | | this.$alert( |
| | | `<div style="padding: 10px;"> |
| | | <h4 style="margin-bottom: 10px; color: #f56c6c;">阳性详情:</h4> |
| | | <div style="background: #fef0f0; padding: 15px; border-radius: 4px; border-left: 4px solid #f56c6c;"> |
| | | <p style="margin: 0; white-space: pre-wrap; line-height: 1.5;">${row.positiveDetails}</p> |
| | | </div> |
| | | </div>`, |
| | | "阳性结果详情", |
| | | { |
| | | dangerouslyUseHTMLString: true, |
| | | confirmButtonText: "关闭", |
| | | customClass: "result-details-dialog", |
| | | showClose: false |
| | | } |
| | | ); |
| | | } else if (row.result === "阳性") { |
| | | this.$message.warning("该阳性记录暂无详情信息"); |
| | | } |
| | | }, |
| | | // 保存所有数据 |
| | | async handleSave() { |
| | | try { |
| | |
| | | }); |
| | | }, |
| | | |
| | | // 5. 修改编辑培养记录方法 |
| | | handleEditCulture(row) { |
| | | this.cultureDialogTitle = "编辑培养记录"; |
| | | this.cultureForm = { ...row }; |
| | | this.cultureForm = { |
| | | ...row, |
| | | positiveDetails: row.positiveDetails || "" // 确保有positiveDetails字段 |
| | | }; |
| | | this.cultureFileList = row.attachments |
| | | ? row.attachments.map(item => ({ |
| | | uid: item.id || Math.random(), |
| | |
| | | this.cultureDialogVisible = true; |
| | | this.$nextTick(() => { |
| | | this.$refs.cultureForm && this.$refs.cultureForm.clearValidate(); |
| | | // 如果编辑时是阳性结果,设置验证规则 |
| | | if (row.result === "阳性") { |
| | | this.cultureRules.positiveDetails = [ |
| | | { required: true, message: "请输入阳性详情", trigger: "blur" } |
| | | ]; |
| | | } |
| | | }); |
| | | }, |
| | | |
| | | // 6. 修改保存培养记录方法 |
| | | handleSaveCulture() { |
| | | this.$refs.cultureForm.validate(valid => { |
| | | if (valid) { |
| | | this.cultureSaveLoading = true; |
| | | |
| | | if (this.cultureForm.id) { |
| | | // 构建保存数据 |
| | | const saveData = { |
| | | ...this.cultureForm, |
| | | // 如果是阴性,清空阳性详情 |
| | | positiveDetails: |
| | | this.cultureForm.result === "阳性" |
| | | ? this.cultureForm.positiveDetails || "" |
| | | : "" |
| | | }; |
| | | |
| | | if (saveData.id) { |
| | | const index = this.cultureList.findIndex( |
| | | item => item.id === this.cultureForm.id |
| | | item => item.id === saveData.id |
| | | ); |
| | | if (index !== -1) { |
| | | this.cultureList.splice(index, 1, { ...this.cultureForm }); |
| | | this.cultureList.splice(index, 1, { ...saveData }); |
| | | } |
| | | } else { |
| | | this.cultureForm.id = Date.now(); |
| | | this.cultureList.push({ ...this.cultureForm }); |
| | | saveData.id = Date.now(); |
| | | this.cultureList.push({ ...saveData }); |
| | | } |
| | | |
| | | this.$message.success(this.cultureForm.id ? "修改成功" : "新增成功"); |
| | | this.$message.success(saveData.id ? "修改成功" : "新增成功"); |
| | | this.cultureDialogVisible = false; |
| | | this.cultureSaveLoading = false; |
| | | } |
| | |
| | | font-size: 13px; |
| | | margin-left: 8px; |
| | | } |
| | | /* 7. 添加一些样式 */ |
| | | .result-details-dialog { |
| | | width: 500px; |
| | | } |
| | | |
| | | .result-details-dialog .el-message-box__content { |
| | | padding: 0; |
| | | } |
| | | |
| | | .result-details-dialog .el-message-box__header { |
| | | background: #fef0f0; |
| | | border-bottom: 1px solid #fde2e2; |
| | | } |
| | | |
| | | .result-details-dialog .el-message-box__title { |
| | | color: #f56c6c; |
| | | font-weight: bold; |
| | | } |
| | | </style> |