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/inout/IoCreateOrder.vue

870 lines
27 KiB
Vue

2 years ago
<template>
<div>
<el-card style="margin: 5px;margin-top: -20px">
<el-form :model="orderFormData" :rules="formRules" ref="dataForm" label-width="100px"
2 years ago
style="margin-bottom: -15px">
<el-button-group style="display: flex;margin: 0px 0 10px 80%; height: 35px">
<el-button
size="mini"
type="primary"
@click.native="saveOrder()"
>草稿保存
</el-button
>
<el-button
size="mini"
type="primary"
@click.native="submit()"
2 years ago
>提交订单
</el-button
>
</el-button-group>
<el-row>
<el-col :span="11">
<el-form-item prop="corpOrderId" label="单据号:">
<el-input v-model="orderFormData.corpOrderId" auto-complete="off" style="width: 90%"
2 years ago
clearable
:disabled="corpOrderIdDisabled"></el-input>
</el-form-item>
</el-col>
<el-col :span="11">
<el-form-item prop="createTime" label="单据时间:">
<el-date-picker
v-model="orderFormData.createTime"
2 years ago
type="datetime"
placeholder="日期"
clearable
value-format="yyyy-MM-dd HH:mm:ss"
2 years ago
:disabled="true"
style="width: 90%"
>
</el-date-picker>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="11">
<el-form-item prop="invCode" label="当前仓库:">
<el-select v-model="orderFormData.invCode" placeholder="当前仓库信息"
2 years ago
style="width: 90%"
clearable
:disabled="corpOrderIdDisabled" @change="changeInv" filterable>
<el-option
v-for="item in curInvOptions"
:key="item.name"
:label="item.name"
:value="item.code">
<span style="float: left">{{ item.name }}</span>
<span style="float: right; color: #8492a6; font-size: 13px">{{
item.code
}}</span>
</el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="11">
<el-form-item prop="action" label="单据类型:">
<el-select v-model="orderFormData.action" placeholder="请选择单据类型"
2 years ago
:disabled="corpOrderIdDisabled"
clearable
style="width: 90%"
@change="actionChange">
<el-option
v-for="item in busTypeOptions"
:key="item.name"
:label="item.name"
:value="item.action">
<span style="float: left">{{ item.name }}</span>
</el-option>
</el-select>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="11">
<el-form-item prop="fromCorp"
label="往来信息:"
v-if="curAction.corpType ==0 || curAction.corpType == 2 || (curAction.corpType == 1 && !curAction.genUnit)"
2 years ago
>
<el-select
v-model="orderFormData.fromCorp"
2 years ago
filterable
remote
clearable
reserve-keyword
style="width: 90%"
placeholder="请输入往来单位"
:remote-method="findMethod"
:loading="loading"
:disabled="corpOrderIdDisabled"
>
<el-option
v-for="item in fromOptions"
:key="item.erpId"
:label="item.name"
:value="item.erpId"
>
<span style="float: left">{{ item.name }}</span>
</el-option>
</el-select>
</el-form-item>
<el-form-item prop="fromCorp"
v-if="curAction.corpType ==3"
2 years ago
label="往来信息:"
>
<el-select v-model="orderFormData.fromInvCode" placeholder="请选择往来仓库"
:disabled="corpOrderIdDisabled" filterable
2 years ago
clearable
style="width: 90%"
>
<el-option
v-for="item in fromInvOptions"
:key="item.code"
:label="item.name"
:value="item.code">
<span style="float: left">{{ item.name }}</span>
<span style="float: right; color: #8492a6; font-size: 13px">{{
item.code
}}</span>
</el-option>
</el-select>
</el-form-item>
<el-form-item prop="fromCorp"
v-if="curAction.corpType ==1 && curAction.genUnit">
<el-input v-model="orderFormData.fromCorp" auto-complete="off"
2 years ago
clearable
style="width: 90%"
:disabled="corpOrderIdDisabled"
placeholder="请输入病人住院号"
></el-input>
</el-form-item>
</el-col>
<el-col :span="11">
<el-form-item prop="remark" label="备注:">
<el-input v-model="orderFormData.remark" auto-complete="off"
2 years ago
clearable
style="width: 90%"
placeholder="请输入备注信息"
></el-input>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="20">
<el-form-item prop="code" label="扫码录入:">
<el-input
id="inputer"
@focus="getInputFocus($event)"
@keypress.enter.native="enterKey($event)"
ref='inputRef'
style="ime-mode:disabled"
type="tel"
v-model="codeFormData.code"
2 years ago
></el-input>
</el-form-item>
</el-col>
<el-col :span="2">
<el-button
type="primary"
size="mini"
@click.native.stop="addCode()"
style=" margin-left: 15px"
>添加
</el-button
>
</el-col>
</el-row>
</el-form>
</el-card>
<el-tabs type="border-card" style="margin: 5px">
<el-tab-pane label="业务详情">
<biz-detail-panel :idQuery="orderFormData" v-if="isCodeAlive"></biz-detail-panel>
2 years ago
</el-tab-pane>
<el-tab-pane label="扫码详情">
<codeDetailPanel :idQuery="orderFormData" v-if="isCodeAlive"></codeDetailPanel>
2 years ago
</el-tab-pane>
<el-tab-pane label="扫码明细">
<codesPanel :idQuery="orderFormData" v-if="isCodeAlive"></codesPanel>
2 years ago
</el-tab-pane>
2 years ago
</el-tabs>
<!-- <el-dialog-->
<!-- :title="selectUnitTitle"-->
<!-- :visible.sync="dialogTableVisible"-->
<!-- :close-on-click-modal="false"-->
<!-- :close-on-press-escape="false"-->
<!-- v-if="dialogTableVisible"-->
<!-- width="70%"-->
<!-- append-to-body-->
<!-- >-->
<!-- <DialogSelectUnit-->
<!-- :codeId="curRow"-->
<!-- v-on:selectSupUnit="selectSupUnit"-->
<!-- v-on:closeBindDialog="closeBindDialog"-->
<!-- ></DialogSelectUnit>-->
<!-- </el-dialog>-->
<!-- <el-dialog-->
<!-- :title="selectRlTitle"-->
<!-- :visible.sync="selectRlVisible"-->
<!-- width="80%"-->
<!-- :close-on-click-modal="false"-->
<!-- :close-on-press-escape="false"-->
<!-- v-if="selectRlVisible"-->
<!-- append-to-body-->
<!-- >-->
<!-- <selectRlDialog-->
<!-- :curRow="curRow"-->
<!-- :curAction="curAction"-->
<!-- v-on:selectBindRl="selectBindRl"-->
<!-- v-on:closeBindDialog="closeBindDialog"-->
<!-- ></selectRlDialog>-->
<!-- </el-dialog>-->
<!-- <el-dialog-->
<!-- :title="editTitle"-->
<!-- :visible.sync="editCodeVisible"-->
<!-- append-to-body width="70%"-->
<!-- :close-on-click-modal="false"-->
<!-- :close-on-press-escape="false"-->
<!-- v-if="editCodeVisible"-->
<!-- >-->
<!-- <editCodeDialog-->
<!-- editTye="2"-->
<!-- :closeCodeDialog="closeCodeDialog"-->
<!-- :codeDetail="codeDetail">-->
<!-- </editCodeDialog>-->
<!-- </el-dialog>-->
<!-- <el-dialog-->
<!-- :title="editTitle"-->
<!-- :visible.sync="editOriginCodeVisible"-->
<!-- append-to-body width="70%"-->
<!-- :close-on-click-modal="false"-->
<!-- :close-on-press-escape="false"-->
<!-- v-if="editOriginCodeVisible">-->
<!-- <editCodeDialog-->
<!-- :closeCodeDialog="closeCodeDialog"-->
<!-- :repeatAddCode="repeatAddCode"-->
<!-- :codeDetail="formData"-->
<!-- editTye="1">-->
<!-- </editCodeDialog>-->
<!-- </el-dialog>-->
</div>
</template>
<script>
import {
errorCodeList, addOrderWeb, deleteCodesTempById, submitOrderWeb, saveOrderWeb,
updateCodeBindSup, enterCodeWeb
} from "../../api/inout/order";
import {filterSubByInv, findByFrom, findByInvUser, findInvByUser} from "../../api/system/invSubWarehouse";
2 years ago
import draggable from "vuedraggable";
import {parseTime} from "../../utils/coTools";
import {getBasicUnitMaintains} from "../../api/basic/basicUnitMaintain"
import {filterAllByLoc, filterAllByUser} from "@/api/system/invWarehouse";
import {getLocalJoinByUser} from "../../api/basic/busType";
// import DialogSelectUnit from "./DialogSelectUnit";
// import selectRlDialog from "./DialogSelectRl";
// import editCodeDialog from "./editCode";
import codesPanel from "./IoCreateOrderCodes"
import codeDetailPanel from "./IoCreateOrderCodeDetail"
import bizDetailPanel from "./IoCreateOrderBizDetail"
2 years ago
import A from "../../plugins/KeyScaner"
import {isBlank} from "@/utils/strUtil";
import {filterDepts} from "@/api/auth/authDept";
import {selectSysParamByKey} from "@/api/param/systemParamConfig";
import store from "@/store";
export default {
name: "idQuery",
props: {
closeDialog: {
type: Function,
required: true,
},
idQuery: {
type: Object,
required: true,
},
},
data() {
return {
//单据相关
orderFormData: {
2 years ago
billNo: null,
corpOrderId: null,
action: null,
invCode: null,
fromCorp: null,
fromInvCode: null,
remark: null,
fromType: 2,
},
//扫码相关
codeFormData: {
code: "",
2 years ago
batchNo: null,
produceDate: null,
expireDate: null,
serialNo: null,
},
2 years ago
curInvOptions: [],
busTypeOptions: [],
fromInvOptions: [],
curAction: {
corpType: 0,
genUnit: false,
},
fromOptions: [],
isCodeAlive: true,
2 years ago
editCodeVisible: false,
actionEnable: false,
editOriginCodeVisible: false,
curId: null,
storageList: [],
formRules: {
temp: [
{required: true, message: "请输入条码", trigger: "blur"}
],
},
isScan: true,
scanText: "扫码录入:",
corpOrderIdDisabled: false,
loading: false,
index: null,
formLoading: false,
formVisible: false,
deleteLoading: false,
orderNo: null,
fromStorageOptions: [],
curRow: null,
dialogTableVisible: false,
sitcomScan: false,
selectRlTitle: "绑定产品",
selectUnitTitle: "绑定供应商",
sictomText: "",
originCode: "",
checkSuccess: false,
codeDetail: null,
editTitle: "编辑条码",
fromDeptOptions: [],
enableDept: false
};
},
components: {
draggable,
// DialogSelectUnit, selectRlDialog, editCodeDialog
codesPanel, codeDetailPanel, bizDetailPanel
2 years ago
},
methods: {
//获取用户仓库列表
findInvByUser() {
this.curInvOptions = [];
findInvByUser()
2 years ago
.then((response) => {
this.curInvOptions = response.data || [];
if (this.curInvOptions != null && this.curInvOptions.length == 1) {
this.orderFormData.invWarehouseCode = this.curInvOptions[0].code;
this.getBusTypeByInv()
2 years ago
}
})
.catch(() => {
});
},
//仓库改变
changeInv() {
this.orderFormData.action = null;
2 years ago
this.getBusTypeByInv();
},
//根据仓库,用户获取单据类型
2 years ago
getBusTypeByInv() {
let query = {
code: this.orderFormData.invCode,
2 years ago
};
findByInvUser(query)
.then((response) => {
this.busTypeOptions = response.data || [];
})
.catch(() => {
});
},
//获取往来单位候选列表
findMethod(query) {
this.fromOptions = [];
let cQuery = {
key: query,
corpType: null,
outType: null,
page: 1,
limit: 20
};
if (this.curAction.corpType == 3) {//内部科室
cQuery.corpType = 3;
} else if (this.curAction.corpType == 2)//供应商信息
2 years ago
{
cQuery.corpType = 2;
2 years ago
} else if (this.curAction.corpType == 0) {
cQuery.corpType = 2;
} else return;
getBasicUnitMaintains(cQuery)
.then((response) => {
this.loading = false;
this.fromOptions = response.data.list || [];
})
.catch(() => {
this.loading = false;
});
},
//单据类型改变
actionChange(item) {
this.curAction = this.getActionItem(item);
if (this.curAction.corpType == 0 || this.curAction.corpType == 2 || (this.curAction.corpType == 1 && !this.curAction.genUnit)) {
//1.切换往来单位
this.orderFormData.fromCorp = null;
this.findMethod();
} else if (this.curAction.corpType == 3) {
//2. 切换往来仓库
this.orderFormData.fromInvCode = null;
this.findFromInvList();
}
},
2 years ago
//获取往来仓库列表
findFromInvList(val) {
let cQuery = {
locInvCode: this.orderFormData.invCode,
};
findByFrom(cQuery)
.then((response) => {
this.fromInvOptions = response.data || [];
if (val == 1) {
this.orderFormData.fromInvCode = this.fromInvOptions[0].code;
}
})
.catch(() => {
});
},
2 years ago
//获取当前单据类型
getActionItem(action) {
for (let i = 0; i < this.busTypeOptions.length; i++) {
if (this.busTypeOptions[i].action == action) {
return this.busTypeOptions[i];
}
}
},
2 years ago
//添加条码
addCode(event) {
this.originCode = "";
this.sictomText = "";
this.orderFormData.corpOrderId = this.orderFormData.corpOrderId.trim();
this.codeFormData.batchNo = "";
this.codeFormData.produceDate = "";
this.codeFormData.expireDate = "";
this.codeFormData.serialNo = "";
this.actionEnable = true;
if (event == null) {
} else event.target.select();
this.$refs.inputRef.select();
if (this.$isBlank(this.orderFormData.action)) {
this.$message.warning("请选择单据类型!");
return;
}
if (this.$isBlank(this.orderFormData.corpOrderId)) {
let date = new Date();
this.orderFormData.corpOrderId = parseTime(date, '{y}{m}{d}{h}{i}{s}') + Math.ceil(Math.random() * 89 + 10);
}
this.codeFormData.code = this.codeFormData.code.trim();
if (this.$isBlank(this.codeFormData.code)) return;
this.loading = true;
let tQuery = Object.assign(JSON.parse(JSON.stringify(this.orderFormData)));
tQuery.code = this.codeFormData.code;
this.addCodeSubmit(tQuery);
this.$refs.inputRef.select();
2 years ago
},
//添加条码后提交
addCodeSubmit(tQuery) {
addOrderWeb(tQuery).then((response) => {
if (response.code === 20000) {
this.idQuery.billNo = response.data.orderId;
if (response.data.errMsg != null) {
this.$alert(response.data.errMsg, '提示', {
confirmButtonText: '确定',
type: 'warning',
closeOnClickModal: true,
callback: action => {
}
});
}
this.corpOrderIdDisabled = true;
this.refreshCodesPanel();
this.$refs.inputRef.focus();
this.$refs.inputRef.select();
} else {
if (response.code == 502) {
this.curRow = response.data;
this.idQuery.billNo = this.curRow.orderId;
this.refreshCodesPanel();
this.selectRlTitle = response.message;
this.bindRl(response.data);
} else if (response.code == 503) {
this.curRow = response.data;
this.idQuery.billNo = this.curRow.orderId;
this.refreshCodesPanel();
this.selectUnitTitle = response.message;
this.handleUnitClick(response.data);
} else if (response.code == 504) {
this.$confirm(response.message, "提示", {
confirmButtonText: "确定",
cancelButtonText: "忽略",
type: "error",
}).then(() => {
tQuery.ignoreExpire = true;
this.addCodeSubmit(tQuery)
}).catch(() => {
});
} else if (response.code == 505) {
this.$confirm(response.message, "提示", {
confirmButtonText: "确定",
cancelButtonText: "忽略",
type: "warning",
}).then(() => {
tQuery.ignoreRecentExpire = true;
this.addCodeSubmit(tQuery)
}).catch(() => {
});
} else if (response.code == 507) {
this.editOriginCodeVisible = true;
this.editTitle = response.message;
this.codeFormData.produceDate = response.data.produceDate;
this.codeFormData.expireDate = response.data.expireDate;
this.codeFormData.batchNo = response.data.batchNo;
this.codeFormData.serialNo = response.data.serialNo;
this.$message({
type: 'error',
message: "提交失败!" + this.editTitle,
customClass: 'messageIndex'
});
} else {
this.$alert(response.message, '提示', {
confirmButtonText: '确定',
type: 'warning',
closeOnClickModal: true,
callback: action => {
this.$refs.inputRef.focus();
this.$refs.inputRef.select();
}
});
}
}
this.loading = false;
});
},
refreshCodesPanel() {
this.isCodeAlive = false;
this.$nextTick(() => { //重新加载组件
this.isCodeAlive = true
})
},
2 years ago
submit() {
let tQuery = Object.assign(JSON.parse(JSON.stringify(this.orderFormData)));
tQuery.orderId = this.idQuery.billNo;
2 years ago
submitOrderWeb(tQuery)
.then((response) => {
if (response.code === 20000) {
this.$message.success("提交成功");
this.closeDialog();
} else {
this.$message.error(response.message);
}
this.loading = false;
});
},
saveOrder() {
let tQuery = Object.assign(JSON.parse(JSON.stringify(this.orderFormData)));
tQuery.orderId = this.idQuery.billNo;
2 years ago
saveOrderWeb(tQuery).then((response) => {
if (response.code === 20000) {
this.closeDialog();
} else {
this.$message.error(response.message);
}
this.loading = false;
});
},
closeCodeDialog() {
this.editCodeVisible = false;
this.editOriginCodeVisible = false;
this.getCodeList();
},
// 刷新表单
resetForm() {
if (this.$refs["dataForm"]) {
// 清空验证信息表单
this.$refs["dataForm"].clearValidate();
// 刷新表单
this.$refs["dataForm"].resetFields();
this.getList();
}
},
enterKey(event) {
this.checkSuccess = true;
let tQuery = {
originCode: this.originCode,
code: this.codeFormData.code.trim(),
2 years ago
}
enterCodeWeb(tQuery).then((response) => {
if (response.code === 20000) {
this.$refs.inputRef.focus();
this.$refs.inputRef.select();
this.codeFormData.code = response.data;
2 years ago
this.addCode();
} else {
if (response.code == 502) {
this.checkSuccess = false;
this.codeFormData.code = response.data;
this.originCode = this.codeFormData.code;
2 years ago
} else if (response.code == 501) {
this.checkSuccess = false;
this.$message.error(response.message);
} else if (response.code == 503) {
this.checkSuccess = false;
this.codeFormData.code = response.data;
2 years ago
this.$confirm(response.message, "提示", {
type: "warning",
})
.then(() => {
this.codeFormData.code = response.data;
2 years ago
this.addCode();
})
.catch(() => {
this.codeFormData.code = this.originCode;
2 years ago
});
} else if (response.code == 508) {
this.originCode = "";
this.codeFormData.code = "01" + response.data.nameCode;
this.originCode = this.codeFormData.code;
2 years ago
} else {
this.$alert(response.message, '提示', {
confirmButtonText: '确定',
type: 'warning',
closeOnClickModal: true,
callback: action => {
this.$refs.inputRef.focus();
this.$refs.inputRef.select();
}
});
}
}
this.loading = false;
});
},
repeatAddCode(editData) {
let tQuery = editData;
tQuery.orderId = this.idQuery.id;
tQuery.actDate = parseTime(this.orderFormData.actDate, '{y}-{m}-{d} {h}:{i}:{s}');
tQuery.action = this.orderFormData.action;
2 years ago
this.closeCodeDialog();
this.addCodeSubmit(tQuery);
},
getInputFocus(event) {
event.currentTarget.select();
},
tableSelection() {
this.$refs.multipleTable.clearSelection();
this.$refs.multipleTable.toggleAllSelection();
},
handleSizeChange(val) {
this.query.limit = val;
this.getCodeList();
},
handleCurrentChange(val) {
this.query.page = val;
this.getCodeList();
},
intentBack() {
this.$router.go(-1);
},
selectSupUnit(row) {
let query = {
id: this.curRow.id,
supId: row.erpId,
};
updateCodeBindSup(query).then((response) => {
if (response.code == 20000) {
this.$message.success("绑定成功");
this.idQuery.id = this.curRow.orderId;
this.getCodeList();
} else {
this.$message.error(response.message);
}
}).catch(() => {
});
},
selectBindRl(row) {
let query = {
id: this.curRow.id,
relId: row.id,
mySupId: row.unitFk,
};
updateCodeBindSup(query).then((response) => {
if (response.code == 20000) {
this.$message.success("绑定成功");
this.idQuery.id = this.curRow.orderId;
this.getCodeList();
} else {
if (response.code == 503) {
this.curRow = response.data;
this.idQuery.id = this.curRow.orderId;
this.getCodeList();
this.selectUnitTitle = response.message;
this.handleUnitClick(response.data);
} else
this.$message.error(response.message);
}
}).catch(() => {
});
},
closeBindDialog(val) {
this.selectRlVisible = false;
this.dialogTableVisible = false;
},
},
filters: {},
mounted() {
document.body.ondrop = function (event) {
event.preventDefault();
event.stopPropagation();
};
var that = this;
var inputer = document.getElementById("inputer");
window.sc = new A.KeyScaner(inputer);//传入要监听的DOM节点
sc.onInput = function (text) {
if (text.includes("delete")) {
that.codeFormData.code = "";
2 years ago
that.sictomText = "";
that.originCode = "";
return;
}
if (that.sitcomScan) {
let tempTxt = text;
let str = tempTxt.replace(/[\r]/g, "");
that.sictomText = that.sictomText + str;
that.codeFormData.code = that.sictomText;
2 years ago
} else {
that.codeFormData.code = text;
2 years ago
}
};
inputer.focus();
},
created() {
this.codeFormData.code = '';
2 years ago
this.codeArray = [];
if (this.$isNotBlank(this.idQuery.billNo)) {
2 years ago
this.corpOrderIdDisabled = true;
this.orderFormData = this.idQuery;
2 years ago
this.actionEnable = true;
this.refreshCodesPanel();
//选择框候选数据
this.findInvByUser();
this.getBusTypeByInv();
this.findMethod(this.orderFormData.fromCorp);
this.findFromInvList();
2 years ago
} else {
this.corpOrderIdDisabled = false;
let date = new Date();
this.orderFormData.createTime = parseTime(date, '{y}-{m}-{d} {h}:{i}:{s}');
this.orderFormData.corpOrderId = parseTime(date, '{y}{m}{d}{h}{i}{s}') + Math.ceil(Math.random() * 89 + 10);
this.orderFormData.deptCode = this.$store.getters.deptCode;
this.orderFormData.invCode = this.$store.getters.locInvCode;
this.findInvByUser();
2 years ago
}
}
,
}
;
2 years ago
</script>
<style>
#inputer {
width: 100%;
min-height: 30px;
background-color: white;
border: #d0d0d0;
border-style: solid;
border-width: 0.1px;
color: #4a4a4a;
}
#inputer:focus {
width: 100%;
min-height: 30px;
background-color: white;
border: #0080FF;
border-style: solid;
border-width: 0.1px;
color: #4a4a4a;
}
.ime-disabled {
ime-mode: disabled;
}
</style>