151 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			151 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
|   <div class="app-container">
 | |
|     <el-dialog
 | |
|       title="医保药品目录"
 | |
|       v-model="visible"
 | |
|       width="1500px"
 | |
|       append-to-body
 | |
|       destroy-on-close
 | |
|       @close="cancel"
 | |
|     >
 | |
|       <div>
 | |
|         <el-input
 | |
|           v-model="queryParams.searchKey"
 | |
|           placeholder="请输入药品名"
 | |
|           clearable
 | |
|           style="width: 20%; margin-bottom: 10px"
 | |
|           @keyup.enter="getList"
 | |
|         >
 | |
|           <template #append>
 | |
|             <el-button icon="Search" @click="getList" />
 | |
|           </template>
 | |
|         </el-input>
 | |
|       </div>
 | |
|       <el-table v-loading="listLoading" border :data="list" highlight-current-row max-height="450">
 | |
|         <el-table-column align="center" label="医保目录编码" prop="medicalCatalogCode" />
 | |
|         <el-table-column align="center" label="药品名称" prop="registeredName">
 | |
|           <template #default="scope">
 | |
|             <span v-if="props.currentCategoryEnum == '4'">{{ scope.row.singleDrugName }}</span>
 | |
|             <span v-else>{{ scope.row.registeredName }}</span>
 | |
|           </template>
 | |
|         </el-table-column>
 | |
|         <el-table-column align="center" label="药品类别" prop="drugCategoryName">
 | |
|           <template #default="scope">
 | |
|             {{ formatStr(scope.row.drugCategoryName) }}
 | |
|           </template>
 | |
|         </el-table-column>
 | |
|         <el-table-column align="center" label="药品规格" prop="drugSpecification">
 | |
|           <template #default="scope">
 | |
|             <span v-if="props.currentCategoryEnum == '4'">{{ scope.row.conventionalUsage }}</span>
 | |
|             <span v-else>{{ scope.row.drugSpecification }}</span>
 | |
|           </template>
 | |
|         </el-table-column>
 | |
|         <el-table-column align="center" label="处方药" prop="otcFlagName">
 | |
|           <template #default="scope">
 | |
|             {{ formatStr(scope.row.otcFlagName) }}
 | |
|           </template>
 | |
|         </el-table-column>
 | |
|         <el-table-column align="center" label="批准文号" prop="approvalNo" />
 | |
|         <el-table-column align="center" label="操作" width="80">
 | |
|           <template #default="scope">
 | |
|             <el-button link type="primary" @click="handlewAddMedicine(scope.row)"> 对照 </el-button>
 | |
|           </template>
 | |
|         </el-table-column>
 | |
|       </el-table>
 | |
|       <pagination
 | |
|         v-show="total > 0"
 | |
|         :total="total"
 | |
|         v-model:page="queryParams.pageNo"
 | |
|         v-model:limit="queryParams.pageSize"
 | |
|         @pagination="getList"
 | |
|       />
 | |
|       <template #footer>
 | |
|         <div class="dialog-footer">
 | |
|           <el-button @click="cancel">取 消</el-button>
 | |
|         </div>
 | |
|       </template>
 | |
|     </el-dialog>
 | |
|   </div>
 | |
| </template>
 | |
| 
 | |
| <script setup>
 | |
| import { getYbMedicationList, queryYbCatalogue } from './medicine';
 | |
| 
 | |
| const emit = defineEmits(['selectMedicine']);
 | |
| const visible = ref(false);
 | |
| const total = ref(0);
 | |
| const listLoading = ref(false);
 | |
| const props = defineProps({
 | |
|   currentCategoryEnum: {
 | |
|     type: String,
 | |
|     required: true,
 | |
|   },
 | |
| });
 | |
| const queryParams = ref({
 | |
|   pageNo: 1,
 | |
|   pageSize: 10,
 | |
| });
 | |
| const list = ref([]);
 | |
| function getList() {
 | |
|   (queryParams.value.catalogType = props.currentCategoryEnum == '4' ? 1302 : 1301),
 | |
|     console.log(props.currentCategoryEnum, 'props.currentCategoryEnum');
 | |
| 
 | |
|   listLoading.value = true;
 | |
|   getYbMedicationList(queryParams.value).then((res) => {
 | |
|     total.value = res.data.data.total;
 | |
|     list.value = res.data.data.records;
 | |
|     listLoading.value = false;
 | |
|   });
 | |
| }
 | |
| 
 | |
| function show() {
 | |
|   visible.value = true;
 | |
| }
 | |
| 
 | |
| function cancel() {
 | |
|   visible.value = false;
 | |
| }
 | |
| 
 | |
| function handlewAddMedicine(row) {
 | |
|   queryYbCatalogue({ hilistCode: row.medicalCatalogCode, dateStr: '2020-01-01' }).then((res) => {
 | |
|     if (res.data.length > 0) {
 | |
|       let resultList = res.data.filter((item) => {
 | |
|         return (
 | |
|           item.memo != null &&
 | |
|           item.memo != '' &&
 | |
|           item.memo != 'null' &&
 | |
|           item.memo != '目录变更' &&
 | |
|           item.memo != '历史数据迁移' &&
 | |
|           item.memo != '0' &&
 | |
|           item.memo != ' '
 | |
|         );
 | |
|       });
 | |
|       if (resultList.length > 0) {
 | |
|         row.restrictedFlag = 1;
 | |
|         row.restrictedScope = resultList[0].memo;
 | |
|       }
 | |
|     }
 | |
|     emit('selectMedicine', row);
 | |
|   }).catch(() => {
 | |
|     emit('selectMedicine', row);
 | |
|   });
 | |
|   cancel();
 | |
| }
 | |
| 
 | |
| function formatStr(str) {
 | |
|   if (str === null || str === undefined || str === '' || str === 'null') {
 | |
|     return '-';
 | |
|   }
 | |
|   return str;
 | |
| }
 | |
| 
 | |
| defineExpose({
 | |
|   show,
 | |
| });
 | |
| </script>
 | |
| 
 | |
| <style lang="scss" scoped>
 | |
| :deep(.el-dialog__body .pagination-container .el-pagination) {
 | |
|   padding-right: 20px !important;
 | |
| }
 | |
| </style> | 
