You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
udiwms-vue-frame/src/views/basic/product/bindProduct.vue

335 lines
9.6 KiB
Vue

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

<template>
<div>
<el-card>
<el-form :model="filterQuery" size="mini" label-width="100px" v-show="showSearch">
<el-row>
<el-col :span="18">
<el-form-item class="query-form-item" label="UDI码:">
<el-input v-model="filterQuery.udiCode"
style="width: 97%"
placeholder="请扫描或输入UDI码"
clearable="true"
@keyup.enter.native="keyup_submit($event)"></el-input>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="6">
<el-form-item class="query-form-item" label="产品编码:">
<el-input v-model="filterQuery.unionCode" placeholder="DI/医保编码/商品条码"
style="width: 90%"
clearable="true"></el-input>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item class="query-form-item" label="物资名称:">
<el-input v-model="filterQuery.cpmctymc" placeholder="物资名称" clearable="true"
style="width: 90%"></el-input>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item class="query-form-item" label="规格型号:">
<el-input v-model="filterQuery.ggxh" placeholder="规格型号" clearable="true"
style="width: 90%"></el-input>
</el-form-item>
</el-col>
</el-row>
<el-row>
<!--<el-col :span="6">-->
<!-- <el-form-item class="query-form-item" label="对照条件:">-->
<!-- <el-select v-model="filterQuery.filterType" placeholder="请选择过滤对照条件"-->
<!-- style="width: 90%">-->
<!-- <el-option-->
<!-- v-for="item in filterList"-->
<!-- :key="item.filterType"-->
<!-- :label="item.sysName"-->
<!-- :value="item.filterType">-->
<!-- <span style="float: left">{{ item.sysName }}</span>-->
<!-- </el-option>-->
<!-- </el-select>-->
<!-- </el-form-item>-->
<!--</el-col>-->
<el-col :span="6">
<el-form-item class="query-form-item" label="注册备案人:">
<el-input v-model="filterQuery.ylqxzcrbarmc" placeholder="生产企业/注册备案人"
style="width: 90%"
clearable="true"></el-input>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item class="query-form-item" label="外部产品编码:">
<el-input v-model="filterQuery.thrPiId" placeholder="第三方产品编码"
style="width: 90%"
clearable="true"></el-input>
</el-form-item>
</el-col>
</el-row>
</el-form>
<div class="top-right-btn">
<el-button-group>
<el-button icon="el-icon-view" type="primary" @click="hideSearch">显示/隐藏搜索栏</el-button>
<el-button type="primary" icon="el-icon-refresh" @click="onReset">重置</el-button>
<el-button type="primary" icon="el-icon-search" @click="submit">查询</el-button>
<el-button type="primary" icon="el-icon-plus" @click="instentProduct">选入</el-button>
<el-button type="primary" icon="el-icon-search" @click="SelectInstentProduct">查询选入</el-button>
</el-button-group>
</div>
<el-divider style="margin: 15px"></el-divider>
<el-table v-loading="loading" :data="list" style="width: 100%;" @selection-change="handleSelectionChange" border
key="1">
<el-table-column type="selection" width="55" :selectable="selectable"></el-table-column>
<el-table-column label="最小销售产品标识" prop="nameCode" width="140" show-overflow-tooltip></el-table-column>
<!--<el-table-column label="主系统编码" prop="mainId" show-overflow-tooltip></el-table-column>-->
<el-table-column label="生产企业" prop="ylqxzcrbarmc" show-overflow-tooltip></el-table-column>
<el-table-column label="物资名称" prop="cpmctymc" show-overflow-tooltip></el-table-column>
<el-table-column label="规格型号" prop="ggxh" show-overflow-tooltip></el-table-column>
<el-table-column label="注册/备案号" prop="zczbhhzbapzbh" show-overflow-tooltip></el-table-column>
<el-table-column label="器械类别" prop="qxlb" show-overflow-tooltip></el-table-column>
</el-table>
<pagination
v-show="total>0"
:total="total"
:limit.sync="filterQuery.limit"
:page.sync="filterQuery.page"
@pagination="handleCurrentChange"
></pagination>
</el-card>
</div>
</template>
<script>
import {getUdiInfos, thirdSysDetail,} from "@/api/basic/product/udiRelevance";
import {filterByUuid} from "@/api/basic/product/udiInfo";
import {bindBasicHospProduct, saveBasicHospType, getBindList} from "@/api/basic/basicHospType";
import {saveRel, productList, SelectproductList} from "@/api/basic/basicCaterelType";
import {sysFilter} from '@/api/basic/udiRelevance'
import {isBlank} from "@/utils/strUtil";
export default {
props: {
rId: {
type: Object,
required: true,
},
closeDialog: {
type: Function,
required: true,
},
},
data() {
return {
filterQuery: {
page: 1,
limit: 20,
addType: 1,
thrPiId: null,
filterType: null,
diType: 1,
bindType: 1
},
productList: [],
loading: false,
showSearch: true,
productType: null,
editQuery: null,
editFormat: {},
pId: 0,
productRemarkSet: {},
list: [],
detailList: [],
sysList: [],
filterList: [],
total: 0,
thirdNo: "",
};
},
methods: {
onReset() {
this.$router.push({
path: "",
});
this.filterQuery = {
lockStatus: null,
unionCode: null,
udiCode: null,
ylqxzcrbarmc: "",
cpmctymc: "",
thrPiId: null,
nameCode: "",
ggxh: null,
page: 1,
limit: 20,
addType: 1,
diType: 1,
bindType: 1,
parentCode:this.rId
};
this.getList();
},
submit() {
this.loading = true;
this.filterQuery.page = 1;
this.getList();
},
SelectInstentProduct(){
if( isBlank(this.filterQuery.udiCode) && isBlank(this.filterQuery.unionCode) &&
isBlank(this.filterQuery.cpmctymc) && isBlank(this.filterQuery.ggxh)
&& isBlank(this.filterQuery.ylqxzcrbarmc) && isBlank(this.filterQuery.thrPiId)){
this.$message("请先输入搜索条件!")
return;
}
this.filterQuery.page = 1;
this.getselectList();
},
getSysFilter() {
sysFilter()
.then((response) => {
this.loading = false;
this.filterList = response.data.list || [];
})
.catch(() => {
this.loading = false;
this.filterList = [];
});
},
getList() {
productList(this.filterQuery)
.then((response) => {
this.loading = false;
this.list = response.data.list || [];
this.total = response.data.total || 0;
})
.catch(() => {
this.loading = false;
this.list = [];
this.total = 0;
});
},
keyup_submit(event) {
this.filterQuery.page = 1;
this.getList();
event.target.select();
},
getselectList(){
SelectproductList(this.filterQuery)
.then((res) =>{
if(res.code == 20000){
this.$message.success("选入成功!");
this.closeDialog();
}else{
this.$message.error(res.message);
}
})
},
selectable(row, index) {
if (row.bindCheck == true) {
return false;
} else {
return true;
}
},
hideSearch() {
this.showSearch = !this.showSearch;
},
handleSelectionChange(val) {
this.productList = val;
},
handleCurrentChange(val) {
this.filterQuery.page = val.page;
this.getList();
},
instentProduct() {
if (this.productList.length <= 0) {
this.$message.error("请先选择要绑定的产品");
return;
}
var ids = this.productList.map((item) => item.id)
var data = {code: this.rId, ids: ids}
saveRel(data).then((response) => {
debugger
if (response.code == 20000) {
this.$message.success("选入成功!");
this.closeDialog();
} else {
this.$message.error(response.message);
}
}).catch(() => {
});
},
},
mounted() {
},
components: {},
created() {
this.filterQuery.parentCode=this.rId;
this.getList();
this.getSysFilter();
},
};
</script>
<style scoped>
.itemTag {
float: left;
text-align: right;
margin-top: 5px;
padding-right: 10px;
width: 35%;
}
.text {
font-size: 13px;
font-family: "Microsoft YaHei";
}
.query-form-item {
display: block !important;
margin-right: 10px;
margin-bottom: 5px;
}
.edit-row {
display: flex;
flex-wrap: wrap;
margin-bottom: 0px;
}
.el-row {
display: flex;
flex-wrap: wrap;
margin-bottom: 6px;
}
.el-col {
border-radius: 4px;
flex-wrap: wrap;
}
.el-table .cell.el-tooltip {
white-space: pre-wrap;
}
.form-title {
font-size: 16px;
font-family: Noto Sans SC;
font-weight: bold;
color: #303133;
padding-bottom: 17px;
padding-top: 17px;
}
</style>