单据管理,新增等待,异常,已完成等

master
anthonywj 3 years ago
parent c88ca86e65
commit 9b83d36642

File diff suppressed because one or more lines are too long

@ -5,7 +5,7 @@
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width,initial-scale=1.0"> <meta name="viewport" content="width=device-width,initial-scale=1.0">
<link rel="icon" href="<%= BASE_URL %>favicon.ico"> <link rel="icon" href="<%= BASE_URL %>favicon.ico">
<title>医院供应商自助平台</title> <title>医院UDI自助管理平台</title>
</head> </head>
<body> <body>
<div id="app"></div> <div id="app"></div>

@ -1,6 +1,6 @@
<!DOCTYPE html><html><head><meta charset=utf-8><meta http-equiv=X-UA-Compatible content="IE=edge"><meta name=viewport content="width=device-width,initial-scale=1"><link rel=icon href=favicon.ico><title>医院供应商自助平台</title><link rel=stylesheet href=https://unpkg.com/element-ui/lib/theme-chalk/index.css><link href=css/home.5235ad9e.css rel=prefetch><link href=js/home.fd43d6b8.js rel=prefetch><link href=css/app.55245d3e.css rel=preload as=style><link href=css/chunk-vendors.072ae084.css rel=preload as=style><link href=js/app.83283916.js rel=preload as=script><link href=js/chunk-vendors.ac7bf19a.js rel=preload as=script><link href=css/chunk-vendors.072ae084.css rel=stylesheet><link href=css/app.55245d3e.css rel=stylesheet></head><body><div id=app></div><script src=./tinymce4.7.5/tinymce.min.js></script><script src=https://unpkg.zhimg.com/vue@2.6.14/dist/vue.runtime.min.js></script><script src=https://unpkg.zhimg.com/vuex@3.6.2/dist//vuex.min.js></script><script src=https://unpkg.zhimg.com/vue-router@3.0.1/dist/vue-router.min.js></script><script src=https://unpkg.zhimg.com/element-ui@2.15.7/lib/index.js></script><script>ga('create', 'UA-110990780-1', 'auto'); <!DOCTYPE html><html><head><meta charset=utf-8><meta http-equiv=X-UA-Compatible content="IE=edge"><meta name=viewport content="width=device-width,initial-scale=1"><link rel=icon href=favicon.ico><title>医院UDI自助管理平台</title><link rel=stylesheet href=https://unpkg.com/element-ui/lib/theme-chalk/index.css><link href=css/home.5235ad9e.css rel=prefetch><link href=js/home.1a94cfbc.js rel=prefetch><link href=css/app.aff94608.css rel=preload as=style><link href=css/chunk-vendors.072ae084.css rel=preload as=style><link href=js/app.0b49955d.js rel=preload as=script><link href=js/chunk-vendors.ac7bf19a.js rel=preload as=script><link href=css/chunk-vendors.072ae084.css rel=stylesheet><link href=css/app.aff94608.css rel=stylesheet></head><body><div id=app></div><script src=./tinymce4.7.5/tinymce.min.js></script><script src=https://unpkg.zhimg.com/vue@2.6.14/dist/vue.runtime.min.js></script><script src=https://unpkg.zhimg.com/vuex@3.6.2/dist//vuex.min.js></script><script src=https://unpkg.zhimg.com/vue-router@3.0.1/dist/vue-router.min.js></script><script src=https://unpkg.zhimg.com/element-ui@2.15.7/lib/index.js></script><script>ga('create', 'UA-110990780-1', 'auto');
ga('send', 'pageview'); ga('send', 'pageview');
window.addEventListener('hashchange', function () { window.addEventListener('hashchange', function () {
ga('set', 'page', window.location.href); ga('set', 'page', window.location.href);
ga('send', 'pageview'); ga('send', 'pageview');
});</script><script src=js/chunk-vendors.ac7bf19a.js></script><script src=js/app.83283916.js></script></body></html> });</script><script src=js/chunk-vendors.ac7bf19a.js></script><script src=js/app.0b49955d.js></script></body></html>

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

@ -1,4 +1,4 @@
{ {
"BASE_URL":"http://192.168.0.109:9996", "BASE_URL":"http://127.0.0.1:9996",
"SERVER_IP": "http://192.168.0.109:9996" "SERVER_IP": "http://127.0.0.1:9996"
} }

@ -5,7 +5,7 @@
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width,initial-scale=1.0"> <meta name="viewport" content="width=device-width,initial-scale=1.0">
<link rel="icon" href="<%= BASE_URL %>favicon.ico"> <link rel="icon" href="<%= BASE_URL %>favicon.ico">
<title>医院供应商自助平台</title> <title>医院UDI自助管理平台</title>
</head> </head>
<body> <body>
<div id="app"></div> <div id="app"></div>

@ -5,7 +5,7 @@
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width,initial-scale=1.0"> <meta name="viewport" content="width=device-width,initial-scale=1.0">
<link rel="icon" href="<%= BASE_URL %>favicon.ico"> <link rel="icon" href="<%= BASE_URL %>favicon.ico">
<title>医院供应商自助平台</title> <title>医院UDI自助管理平台</title>
<!-- <link rel="stylesheet" href="https://unpkg.zhimg.com/element-ui/lib/theme-chalk/index.css">--> <!-- <link rel="stylesheet" href="https://unpkg.zhimg.com/element-ui/lib/theme-chalk/index.css">-->
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css"> <link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">

@ -0,0 +1,34 @@
import axios from "../../utils/axios";
// 权限管理
// 获取列表
export function filterList(query) {
return axios({
url: "/spms/inv/warehouse/filter",
method: "get",
params: query
});
}
// 保存
export function saveWarehouse(data, formName, method = "post") {
let url =
formName !== "edit"
? "/spms/inv/warehouse/save"
: "/spms/inv/warehouse/edit";
return axios({
url: url,
method: method,
data: data
});
}
// 删除
export function deleteWarehouse(data) {
return axios({
url: "/spms/inv/warehouse/delete",
method: "post",
data: data
});
}

@ -11,6 +11,7 @@ export function systemPDFTemplateList(query) {
params: query params: query
}); });
} }
export function systemPDFModuleList(query) { export function systemPDFModuleList(query) {
return axios({ return axios({
url: "/system/pdf/module/list", url: "/system/pdf/module/list",
@ -19,6 +20,24 @@ export function systemPDFModuleList(query) {
}); });
} }
export function moduleDetail(query) {
return axios({
url: "/system/pdf/module/detail",
method: "get",
params: query
});
}
export function updateDetailRel(query) {
return axios({
url: "/system/pdf/module/updateRl",
method: "post",
data: query
});
}
export function getSystemPDFModules(query) { export function getSystemPDFModules(query) {
return axios({ return axios({
url: "/system/pdf/module/pdfModules", url: "/system/pdf/module/pdfModules",

@ -61,6 +61,8 @@ import BussinessType from "../views/basic/BussinessType.vue";
import BussinessTypeLocl from "../views/basic/BussinessTypeLocl.vue"; import BussinessTypeLocl from "../views/basic/BussinessTypeLocl.vue";
//基础数据维护 //基础数据维护
import invWarehouse from "../views/basic/invWarehouse"
import udiInfoExport from "../views/basic/UdiinfoExport.vue"; import udiInfoExport from "../views/basic/UdiinfoExport.vue";
import UdiInfoManage from "../views/basic/UdiInfoManage.vue"; import UdiInfoManage from "../views/basic/UdiInfoManage.vue";
import UdiInfoManageSp from "../views/basic/UdiInfoManageSp.vue" import UdiInfoManageSp from "../views/basic/UdiInfoManageSp.vue"
@ -372,6 +374,15 @@ export const asyncRouterMap = [
authRule: ["basicProduct"] authRule: ["basicProduct"]
}, },
children: [ children: [
{
path: "invWarehouse",
component: invWarehouse,
name: "仓库信息",
icon: "",
meta: {
authRule: ["basicProduct/invWarehouse"]
}
},
{ {
path: "/udiInfo", path: "/udiInfo",
@ -586,7 +597,6 @@ export const asyncRouterMap = [
}, },
] ]
} }
@ -769,51 +779,6 @@ export const asyncRouterMap = [
authRule: ["inout"] authRule: ["inout"]
}, },
children: [ children: [
{
path: "/scanOrder",
component: Empty,
name: "扫码单据管理",
redirect: "/scanOrder/errorOrder",
meta: {
authRule: ["inout/scanOrder"]
},
children: [
{
path: "errorOrder",
component: errorOrder,
name: "新增扫码单据",
meta: {
authRule: ["inout/errorOrder"]
}
},
{
path: "waitOrder",
name: "等待校验单据",
component: waitOrder,
meta: {
authRule: ["inout/waitOrder"]
}
},
{
path: "main",
name: "扫码单据查询",
component: inout,
meta: {
authRule: ["inout/main"]
}
},
{
path: "ioCheckOrder",
name: "校验异常单据",
component: ioCheckOrder,
meta: {
authRule: ["inout/ioCheckOrder"]
}
},
]
},
{ {
path: "/busOrder", path: "/busOrder",
component: Empty, component: Empty,
@ -889,7 +854,49 @@ export const asyncRouterMap = [
// } // }
] ]
}, },
{
path: "/scanOrder",
component: Empty,
name: "扫码单据管理",
redirect: "/scanOrder/errorOrder",
meta: {
authRule: ["inout/scanOrder"]
},
children: [
{
path: "errorOrder",
component: errorOrder,
name: "新增扫码单据",
meta: {
authRule: ["inout/errorOrder"]
}
},
{
path: "waitOrder",
name: "等待校验单据",
component: waitOrder,
meta: {
authRule: ["inout/waitOrder"]
}
},
{
path: "main",
name: "扫码单据查询",
component: inout,
meta: {
authRule: ["inout/main"]
}
},
{
path: "ioCheckOrder",
name: "校验异常单据",
component: ioCheckOrder,
meta: {
authRule: ["inout/ioCheckOrder"]
}
},
]
},
{ {
path: "stockOrderSearch", path: "stockOrderSearch",
component: stockOrderSearch, component: stockOrderSearch,

@ -83,7 +83,6 @@
</el-card> </el-card>
<el-card class="el-card"> <el-card class="el-card">
<el-table v-loading="loading" :data="detailList" style="width: 100%"> <el-table v-loading="loading" :data="detailList" style="width: 100%">
<el-table-column label="序号" type="index" show-overflow-tooltip="true"></el-table-column> <el-table-column label="序号" type="index" show-overflow-tooltip="true"></el-table-column>
<el-table-column label="接口名称" prop="name" show-overflow-tooltip="true"></el-table-column> <el-table-column label="接口名称" prop="name" show-overflow-tooltip="true"></el-table-column>

@ -20,6 +20,10 @@
<el-button-group style="margin-left: 10px;display:flex;"> <el-button-group style="margin-left: 10px;display:flex;">
<el-button type="primary" icon="el-icon-refresh" @click="onReset"></el-button> <el-button type="primary" icon="el-icon-refresh" @click="onReset"></el-button>
<el-button type="primary" icon="search" @click="getList"></el-button> <el-button type="primary" icon="search" @click="getList"></el-button>
<el-button type="primary" icon="search" @click="handleAddClick"
>新增
</el-button
>
<el-upload <el-upload
:action="uploadFileUrl" :action="uploadFileUrl"
multiple multiple
@ -32,9 +36,6 @@
</el-upload> </el-upload>
</el-button-group> </el-button-group>
<!-- <el-button type="primary" icon="search" @click="handleAddClick"
>新增</el-button
> -->
</el-form-item> </el-form-item>
</el-form> </el-form>
@ -72,7 +73,15 @@
>编辑 >编辑
</el-button </el-button
> >
<el-button
type="text"
size="small"
@click.native.stop="deleteDialog(scope.row)"
>删除
</el-button
>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
@ -181,7 +190,7 @@ export default {
true: "是", true: "是",
false: "否", false: "否",
}, },
fileList: [],
total: 0, total: 0,
multipleSelection: [], multipleSelection: [],
uploadFileUrl: null, uploadFileUrl: null,
@ -205,7 +214,9 @@ export default {
this.modifyDialogVisible = false; this.modifyDialogVisible = false;
this.addDialogVisible = false; this.addDialogVisible = false;
}, },
handleChange() {
this.getList();
},
getList() { getList() {
this.loading = true; this.loading = true;
getJoinBussinessType(this.filterQuery) getJoinBussinessType(this.filterQuery)
@ -256,6 +267,11 @@ export default {
}); });
}, },
handleAddClick() {
this.inputQuery = {};
this.addDialogVisible = true;
},
handleModifyClick(row) { handleModifyClick(row) {
this.modifyDialogVisible = true; this.modifyDialogVisible = true;
this.inputQuery = { this.inputQuery = {
@ -284,12 +300,11 @@ export default {
secCheckPc: row.secCheckPc, secCheckPc: row.secCheckPc,
secCheckWebNew: row.secCheckWebNew, secCheckWebNew: row.secCheckWebNew,
secCheckChange: row.secCheckChange, secCheckChange: row.secCheckChange,
}; };
}, },
deleteDialog(rowId) { deleteDialog(rowId) {
this.$confirm("此操作将永久删除该业务类型信息, 是否继续?", "提示", { this.$confirm("此操作将永久删除该扫码类型信息, 是否继续?", "提示", {
confirmButtonText: "确定", confirmButtonText: "确定",
cancelButtonText: "取消", cancelButtonText: "取消",
type: "warning", type: "warning",
@ -310,10 +325,15 @@ export default {
deleteBussinessType(tquery) deleteBussinessType(tquery)
.then((response) => { .then((response) => {
this.getList(); this.getList();
this.$message({ if (response.code == 20000) {
type: "success", this.$message({
message: "删除成功!", type: "success",
}); message: "删除成功!",
});
} else {
this.$message.error(response.message);
}
}) })
.catch(() => { .catch(() => {
}); });
@ -322,7 +342,7 @@ export default {
axios.get("./config.json").then(res => { axios.get("./config.json").then(res => {
// //
let response = res.data.BASE_URL; let response = res.data.BASE_URL;
this.uploadFileUrl = response + "udiwms/busstiness/file/upload"; this.uploadFileUrl = response + "/udiwms/busstiness/file/upload";
}); });
}, },
}, },

@ -1,295 +1,304 @@
<template> <template>
<div> <div>
<el-card> <el-card>
<el-form :inline="true" :model="filterQuery" class="query-form" size="mini">
<el-form-item class="query-form-item">
<el-input
v-model="filterQuery.action"
placeholder="业务类型"
style="width: 400px"
></el-input>
</el-form-item>
<el-form-item class="query-form-item">
<el-select v-model="filterQuery.enabled" placeholder="状态">
<el-option label="全部" value=""></el-option>
<el-option label="已启用" value=1></el-option>
<el-option label="未启用" value=0></el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-button-group>
<el-button type="primary" icon="el-icon-refresh" @click="onReset"></el-button>
<el-button type="primary" icon="search" @click="getList"></el-button>
<el-button type="primary" icon="search" @click="handleAddClick"
>新增
</el-button
>
</el-button-group>
</el-form-item>
</el-form>
<el-form :inline="true" :model="filterQuery" class="query-form" size="mini"> <el-table v-loading="loading" :data="list" style="width: 100%">
<el-form-item class="query-form-item"> <el-table-column label="序号" type="index" width="120" fixed></el-table-column>
<el-input
v-model="filterQuery.action"
placeholder="业务类型"
style="width: 400px"
></el-input>
</el-form-item>
<el-form-item class="query-form-item">
<el-select v-model="filterQuery.enabled" placeholder="状态">
<el-option label="全部" value=""></el-option>
<el-option label="已启用" value=1></el-option>
<el-option label="未启用" value=0></el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-button-group>
<el-button type="primary" icon="el-icon-refresh" @click="onReset"></el-button>
<el-button type="primary" icon="search" @click="getList"></el-button>
<el-button type="primary" icon="search" @click="handleAddClick"
>新增
</el-button
>
</el-button-group>
</el-form-item>
</el-form>
<el-table v-loading="loading" :data="list" style="width: 100%"> <el-table-column label="业务单据类型名称" prop="name" fixed></el-table-column>
<el-table-column label="序号" type="index" width="120" fixed></el-table-column> <el-table-column label="业务单据类型代码" prop="action" fixed></el-table-column>
<el-table-column label="第三方单据类型" prop="originAction" fixed></el-table-column>
<el-table-column label="单据是否启用" prop="enable" fixed>
<template slot-scope="scope">
<span>{{ enableMap[scope.row.enable] }}</span>
</template>
</el-table-column>
<el-table-column label="是否预入库" prop="advanceType" fixed>
<template slot-scope="scope">
<span>{{ enableMap[scope.row.advanceType] }}</span>
</template>
</el-table-column>
<el-table-column label="是否自动补单" prop="advanceType" fixed>
<template slot-scope="scope">
<span>{{ enableMap[scope.row.changeEnable] }}</span>
</template>
</el-table-column>
<el-table-column label="是否供应商使用" prop="spUse" fixed>
<template slot-scope="scope">
<span>{{ enableMap[scope.row.spUse] }}</span>
</template>
</el-table-column>
<el-table-column label="业务单据类型名称" prop="name" fixed></el-table-column>
<el-table-column label="业务单据类型代码" prop="action" fixed></el-table-column>
<el-table-column label="原单据类型" prop="originAction" fixed></el-table-column>
<el-table-column label="单据是否启用" prop="enable" fixed>
<template slot-scope="scope">
<span>{{ enableMap[scope.row.enable] }}</span>
</template>
</el-table-column>
<el-table-column label="是否预入库" prop="advanceType" fixed>
<template slot-scope="scope">
<span>{{ enableMap[scope.row.advanceType] }}</span>
</template>
</el-table-column>
<el-table-column label="是否自动补单" prop="advanceType" fixed>
<template slot-scope="scope">
<span>{{ enableMap[scope.row.changeEnable] }}</span>
</template>
</el-table-column>
<el-table-column label="是否供应商使用" prop="spUse" fixed>
<template slot-scope="scope">
<span>{{ enableMap[scope.row.spUse] }}</span>
</template>
</el-table-column>
<el-table-column label="操作" fixed="right">
<template slot-scope="scope">
<el-button
type="text"
size="small"
@click.native.stop="handleModifyClick(scope.row)"
>编辑
</el-button
>
<el-button
type="text"
size="small"
@click.native.stop="deleteDialog(scope.row)"
>删除
</el-button
>
</template>
</el-table-column>
</el-table>
<el-table-column label="操作" fixed="right"> <el-dialog
<template slot-scope="scope"> title="新增业务类型关联"
<el-button :visible.sync="addDialogVisible"
type="text" width="70%"
size="small" :close-on-click-modal="false"
@click.native.stop="handleModifyClick(scope.row)" :close-on-press-escape="false"
>编辑 v-if="addDialogVisible"
</el-button
> >
</template> <modifyDialog :inputQuery="inputQuery"></modifyDialog>
</el-table-column> <div style="text-align: center">
</el-table> <el-button type="primary" size="small" icon="search" @click="onAddSubmit"
>提交
<el-dialog </el-button
title="新增业务类型关联" >
:visible.sync="addDialogVisible" <el-button type="primary" size="small" icon="search" @click="cancelDialog"
width="70%" >取消
:close-on-click-modal="false" </el-button
:close-on-press-escape="false" >
v-if="addDialogVisible" </div>
> </el-dialog>
<modifyDialog :inputQuery="inputQuery"></modifyDialog>
<div style="text-align: center">
<el-button type="primary" size="small" icon="search" @click="onAddSubmit"
>提交
</el-button
>
<el-button type="primary" size="small" icon="search" @click="cancelDialog"
>取消
</el-button
>
</div>
</el-dialog>
<el-dialog <el-dialog
title="编辑业务类型关联" title="编辑业务类型关联"
:visible.sync="modifyDialogVisible" :visible.sync="modifyDialogVisible"
width="70%" width="70%"
:close-on-click-modal="false" :close-on-click-modal="false"
:close-on-press-escape="false" :close-on-press-escape="false"
v-if="modifyDialogVisible" v-if="modifyDialogVisible"
> >
<modifyDialog :inputQuery="inputQuery"></modifyDialog> <modifyDialog :inputQuery="inputQuery"></modifyDialog>
<div style="text-align: center"> <div style="text-align: center">
<el-button type="primary" size="small" icon="search" @click="onModifySubmit" <el-button type="primary" size="small" icon="search" @click="onModifySubmit"
>提交 >提交
</el-button </el-button
> >
<el-button type="primary" size="small" icon="search" @click="cancelDialog" <el-button type="primary" size="small" icon="search" @click="cancelDialog"
>取消 >取消
</el-button </el-button
> >
</div> </div>
</el-dialog> </el-dialog>
</el-card> </el-card>
</div> </div>
</template> </template>
<script> <script>
import {getLocalBusType, addLocalBusType, updateLocalBusType} from "@/api/basic/busLocalType"; import {getLocalBusType, addLocalBusType, updateLocalBusType,deleteLocalBusType} from "@/api/basic/busLocalType";
import modifyDialog from "./BussinessTypeLoclModify"; import modifyDialog from "./BussinessTypeLoclModify";
export default { export default {
data() { data() {
return { return {
filterQuery: { filterQuery: {
enabled: "1", enabled: "1",
udiwmsType: "", udiwmsType: "",
thirdType: "", thirdType: "",
page: 1, page: 1,
limit: 20, limit: 20,
}, },
addDialogVisible: false, addDialogVisible: false,
modifyDialogVisible: false, modifyDialogVisible: false,
list: [], list: [],
inputQuery: { inputQuery: {
action: "", action: "",
name: "", name: "",
enable: "", enable: "",
remark: "", remark: "",
mainAction: "", mainAction: "",
thirdSysFk: "", thirdSysFk: "",
id: "", id: "",
originAction: null, originAction: null,
localAction: null, localAction: null,
advanceType: null, advanceType: null,
changeEnable: null, changeEnable: null,
spUse: null, spUse: null,
}, },
enableMap: { enableMap: {
true: "是", true: "是",
false: "否", false: "否",
}, },
total: 0,
multipleSelection: [],
};
},
methods: { total: 0,
onReset() { multipleSelection: [],
this.$router.push({ };
path: "",
});
this.filterQuery = {
udiwmsType: "",
thirdType: "",
page: 1,
limit: 20,
};
this.getList();
},
cancelDialog() {
this.modifyDialogVisible = false;
this.addDialogVisible = false;
}, },
getList() { methods: {
this.loading = true; onReset() {
getLocalBusType(this.filterQuery) this.$router.push({
.then((response) => { path: "",
this.loading = false; });
this.list = response.data.list || []; this.filterQuery = {
this.total = response.data.total || 0; udiwmsType: "",
}) thirdType: "",
.catch(() => { page: 1,
this.loading = false; limit: 20,
this.list = []; };
this.total = 0; this.getList();
}); },
}, cancelDialog() {
this.modifyDialogVisible = false;
this.addDialogVisible = false;
},
getList() {
this.loading = true;
getLocalBusType(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;
});
},
onAddSubmit() {
addLocalBusType(this.inputQuery)
.then((response) => {
this.loading = false;
this.cancelDialog();
this.getList();
})
.catch(() => {
this.loading = false;
this.cancelDialog();
});
},
onModifySubmit() { onAddSubmit() {
updateLocalBusType(this.inputQuery) addLocalBusType(this.inputQuery)
.then((response) => { .then((response) => {
this.loading = false; this.loading = false;
this.cancelDialog(); this.cancelDialog();
this.getList(); this.getList();
}) })
.catch(() => { .catch(() => {
this.loading = false; this.loading = false;
this.cancelDialog(); this.cancelDialog();
}); });
}, },
handleModifyClick(row) { onModifySubmit() {
this.modifyDialogVisible = true; updateLocalBusType(this.inputQuery)
this.inputQuery = { .then((response) => {
id: row.id, this.loading = false;
remark: row.remark, this.cancelDialog();
action: row.action, this.getList();
name: row.name, })
enable: row.enable, .catch(() => {
mainAction: row.mainAction, this.loading = false;
localAction: row.localAction, this.cancelDialog();
thirdSysFk: row.thirdSysFk, });
originAction: row.originAction, },
advanceType: row.advanceType,
changeEnable: row.changeEnable,
spUse: row.spUse,
};
},
handleAddClick() { handleModifyClick(row) {
this.addDialogVisible = true; this.modifyDialogVisible = true;
this.inputQuery = { this.inputQuery = {
action: "", id: row.id,
name: "", remark: row.remark,
enable: "", action: row.action,
remark: "", name: row.name,
mainAction: "", enable: row.enable,
thirdSysFk: "", mainAction: row.mainAction,
id: "", localAction: row.localAction,
advanceType: null, thirdSysFk: row.thirdSysFk,
localAction: null, originAction: row.originAction,
changeEnable: null, advanceType: row.advanceType,
}; changeEnable: row.changeEnable,
}, spUse: row.spUse,
};
},
deleteDialog(rowId) { handleAddClick() {
this.$confirm("此操作将永久删除该业务类型信息, 是否继续?", "提示", { this.addDialogVisible = true;
confirmButtonText: "确定", this.inputQuery = {
cancelButtonText: "取消", action: "",
type: "warning", name: "",
}) enable: "",
.then(() => { remark: "",
this.deleteOrders(rowId); mainAction: "",
}) thirdSysFk: "",
.catch(() => { id: "",
}); advanceType: null,
}, localAction: null,
changeEnable: null,
};
},
deleteOrders(data) { deleteDialog(rowId) {
this.loading = true; this.$confirm("此操作将永久删除该业务类型信息, 是否继续?", "提示", {
let tquery = { confirmButtonText: "确定",
id: data.id + "", cancelButtonText: "取消",
}; type: "warning",
})
.then(() => {
this.deleteOrders(rowId);
})
.catch(() => {
});
},
deleteBussinessType(tquery) deleteOrders(data) {
.then((response) => { this.loading = true;
this.getList(); let tquery = {
this.$message({ id: data.id + "",
type: "success", };
message: "删除成功!",
}); deleteLocalBusType(tquery)
}) .then((response) => {
.catch(() => { this.getList();
}); if (response.code == 20000) {
this.$message({
type: "success",
message: "删除成功!",
});
} else {
this.$message.error(response.message);
}
})
.catch(() => {
});
},
},
components: {
modifyDialog,
},
mounted() {
},
created() {
this.getList();
}, },
},
components: {
modifyDialog,
},
mounted() {
},
created() {
this.getList();
},
}; };
</script> </script>

@ -23,6 +23,7 @@
style="width: 200px" style="width: 200px"
size="small" size="small"
splaceholder="请输入内容" splaceholder="请输入内容"
disabled
v-model="inputQuery.action" v-model="inputQuery.action"
></el-input> ></el-input>
</div> </div>
@ -34,16 +35,20 @@
<div class="itemTag"> <div class="itemTag">
<span>第三方单据类型:&nbsp;</span> <span>第三方单据类型:&nbsp;</span>
</div> </div>
<el-select v-model="inputQuery.originAction" placeholder="请选择业务类型" clearable="true">
<el-select v-model="inputQuery.originAction" placeholder="请选择第三方系统单据类型" clearable="true">
<el-option <el-option
v-for="item in originTypes" v-for="item in originTypes"
:key="item.name" :key="item.name"
:label="item.name" :label="item.name"
:value="item.action"> :value="item.action">
<span style="float: left">{{ item.name }}</span> <span style="float: left;font-size: 13px">{{ item.name }}</span>
<!--<span style="float: right; color: #8492a6; font-size: 13px">{{ item.action }}</span>--> <span style="float: right; color: #8492a6; font-size: 13px;margin-left: 10px">{{
item.thirdSysName
}}</span>
</el-option> </el-option>
</el-select> </el-select>
</div> </div>
</el-col> </el-col>
@ -88,7 +93,7 @@
</el-col> </el-col>
</el-row> </el-row>
<div v-if="inputQuery.changeEnable"> <div v-if="visibleChange">
<!-- <div style="float:right;margin-bottom: 10px">--> <!-- <div style="float:right;margin-bottom: 10px">-->
@ -244,6 +249,7 @@ export default {
1: "编辑", 1: "编辑",
}, },
changeList: [], changeList: [],
visibleChange: false,
} }
}, },
methods: { methods: {
@ -251,7 +257,14 @@ export default {
this.query.action = this.inputQuery.action; this.query.action = this.inputQuery.action;
getChangeBusType(this.query) getChangeBusType(this.query)
.then((response) => { .then((response) => {
this.changeList = response.data || []; if (response.code == 20000) {
this.changeList = response.data || [];
this.visibleChange = true;
} else {
this.$message.error(response.message);
this.visibleChange = false;
}
}) })
.catch(() => { .catch(() => {
}); });
@ -332,6 +345,8 @@ export default {
if (this.inputQuery.changeEnable) { if (this.inputQuery.changeEnable) {
this.query.type = "changeEnable"; this.query.type = "changeEnable";
this.getList() this.getList()
} else {
this.visibleChange = false;
} }
} }
, ,

@ -10,7 +10,6 @@
style="width: 200px" style="width: 200px"
size="small" size="small"
splaceholder="请输入内容" splaceholder="请输入内容"
:disabled="true"
v-model="inputQuery.name" v-model="inputQuery.name"
></el-input> ></el-input>
</div> </div>
@ -35,15 +34,14 @@
<el-col :span="10" class="el-col"> <el-col :span="10" class="el-col">
<div class="text item"> <div class="text item">
<div class="itemTag"> <div class="itemTag">
<span>出入库类型代码:&nbsp;</span> <span>出入库类型:&nbsp;</span>
</div> </div>
<el-input
style="width: 200px" <el-select v-model="inputQuery.mainAction" placeholder="出入库类型">
:disabled="true" <el-option label="入库" value="WareHouseIn"></el-option>
size="small" <el-option label="出库" value="WareHouseOut"></el-option>
splaceholder="请输入内容" </el-select>
v-model="inputQuery.mainAction"
></el-input>
</div> </div>
</el-col> </el-col>
<!-- <el-col :span="10" class="el-col">--> <!-- <el-col :span="10" class="el-col">-->
@ -76,7 +74,6 @@
:label="item.name" :label="item.name"
:value="item.action"> :value="item.action">
<span style="float: left">{{ item.name }}</span> <span style="float: left">{{ item.name }}</span>
<span style="float: right; color: #8492a6; font-size: 13px">{{ item.action }}</span>
</el-option> </el-option>
</el-select> </el-select>
</div> </div>
@ -85,7 +82,7 @@
<el-row :gutter="20" class="el-row" type="flex"> <el-row :gutter="20" class="el-row" type="flex">
<el-col :span="24" class="el-col"> <el-col :span="10" class="el-col">
<div class="text item"> <div class="text item">
<div class="itemTag"> <div class="itemTag">
<span>备注:&nbsp;</span> <span>备注:&nbsp;</span>
@ -98,46 +95,52 @@
></el-input> ></el-input>
</div> </div>
</el-col> </el-col>
</el-row> <el-col :span="12" class="el-col">
<div class="text item" style="margin-top: 6px">
<el-divider></el-divider>
<el-row :gutter="20" class="el-row" type="flex">
<el-col :span="4" class="el-col">
<div class="text item">
<el-checkbox v-model="inputQuery.enable"></el-checkbox> <el-checkbox v-model="inputQuery.enable"></el-checkbox>
</div>
</el-col>
<el-col :span="4" class="el-col">
<div class="text item">
<el-checkbox v-model="inputQuery.checkEnable"></el-checkbox>
</div>
</el-col>
<el-col :span="4" class="el-col">
<div class="text item">
<el-checkbox v-model="inputQuery.secCheckEnable"></el-checkbox>
</div>
</el-col>
<el-col :span="4" class="el-col">
<div class="text item">
<el-checkbox v-model="inputQuery.innerOrder"></el-checkbox> <el-checkbox v-model="inputQuery.innerOrder"></el-checkbox>
</div>
</el-col>
<el-col :span="4" class="el-col">
<div class="text item">
<el-checkbox v-model="inputQuery.genUnit"></el-checkbox> <el-checkbox v-model="inputQuery.genUnit"></el-checkbox>
</div> </div>
</el-col> </el-col>
</el-row> </el-row>
<el-divider></el-divider>
<el-row :gutter="20" class="el-row" type="flex"> <!-- <el-divider></el-divider>-->
<el-col :span="5" class="el-col"> <!-- <el-row :gutter="20" class="el-row" type="flex">-->
<span>选择业务单据校验的来源类型</span> <!-- <el-col :span="4" class="el-col">-->
<!-- <div class="text item">--> <!-- <div class="text item">-->
<!-- <el-checkbox v-model="inputQuery.checkEnable"></el-checkbox>--> <!-- <el-checkbox v-model="inputQuery.enable"></el-checkbox>-->
<!-- </div>--> <!-- </div>-->
<!-- </el-col>-->
<!-- <el-col :span="4" class="el-col">-->
<!-- <div class="text item">-->
<!-- <el-checkbox v-model="inputQuery.innerOrder"></el-checkbox>-->
<!-- </div>-->
<!-- </el-col>-->
<!-- <el-col :span="4" class="el-col">-->
<!-- <div class="text item">-->
<!-- <el-checkbox v-model="inputQuery.genUnit"></el-checkbox>-->
<!-- </div>-->
<!-- </el-col>-->
<!-- </el-row>-->
<el-divider></el-divider>
<el-row :gutter="20" class="el-row" type="flex">
<!-- <el-col :span="5" class="el-col">-->
<!-- <span>选择业务单据校验的来源类型</span>-->
<!--&lt;!&ndash; <div class="text item">&ndash;&gt;-->
<!--&lt;!&ndash; <el-checkbox v-model="inputQuery.checkEnable"></el-checkbox>&ndash;&gt;-->
<!--&lt;!&ndash; </div>&ndash;&gt;-->
<!-- </el-col>-->
<el-col :span="4" class="el-col">
<div class="text item">
<el-checkbox v-model="inputQuery.checkEnable">()</el-checkbox>
</div>
</el-col> </el-col>
</el-row> </el-row>
<el-row :gutter="20" class="el-row" type="flex"> <el-row :gutter="20" class="el-row" type="flex" style="margin-left: 15px">
<el-col :span="4" class="el-col"> <el-col :span="4" class="el-col">
<div class="text item"> <div class="text item">
<el-checkbox v-model="inputQuery.checkWebNew" :disabled="!inputQuery.checkEnable">web <el-checkbox v-model="inputQuery.checkWebNew" :disabled="!inputQuery.checkEnable">web
@ -169,19 +172,27 @@
</el-col> </el-col>
<el-col :span="4" class="el-col"> <el-col :span="4" class="el-col">
<div class="text item"> <div class="text item">
<el-checkbox v-model="inputQuery.checkChange" :disabled="!inputQuery.checkEnable"></el-checkbox> <el-checkbox v-model="inputQuery.checkChange" :disabled="!inputQuery.checkEnable">
</el-checkbox>
</div> </div>
</el-col> </el-col>
</el-row> </el-row>
<el-divider></el-divider>
<el-row :gutter="20" class="el-row" type="flex"> <el-row :gutter="20" class="el-row" type="flex">
<el-col :span="5" class="el-col"> <!-- <el-col :span="5" class="el-col">-->
<span>单据需要复核的来源类型</span> <!-- <span>单据需要复核的来源类型</span>-->
<!-- <div class="text item">--> <!-- &lt;!&ndash; <div class="text item">&ndash;&gt;-->
<!-- <el-checkbox v-model="inputQuery.checkEnable"></el-checkbox>--> <!-- &lt;!&ndash; <el-checkbox v-model="inputQuery.checkEnable"></el-checkbox>&ndash;&gt;-->
<!-- </div>--> <!-- &lt;!&ndash; </div>&ndash;&gt;-->
<!-- </el-col>-->
<el-col :span="4" class="el-col">
<div class="text item">
<el-checkbox v-model="inputQuery.secCheckEnable">()</el-checkbox>
</div>
</el-col> </el-col>
</el-row> </el-row>
<el-row :gutter="20" class="el-row" type="flex"> <el-row :gutter="20" class="el-row" type="flex" style="margin-left: 15px">
<el-col :span="4" class="el-col"> <el-col :span="4" class="el-col">
<div class="text item"> <div class="text item">
<el-checkbox v-model="inputQuery.secCheckUdims" :disabled="!inputQuery.secCheckEnable">web <el-checkbox v-model="inputQuery.secCheckUdims" :disabled="!inputQuery.secCheckEnable">web
@ -208,12 +219,14 @@
</el-col> </el-col>
<el-col :span="4" class="el-col"> <el-col :span="4" class="el-col">
<div class="text item"> <div class="text item">
<el-checkbox v-model="inputQuery.secCheckWebNew" :disabled="!inputQuery.secCheckEnable">UDI</el-checkbox> <el-checkbox v-model="inputQuery.secCheckWebNew" :disabled="!inputQuery.secCheckEnable">UDI
</el-checkbox>
</div> </div>
</el-col> </el-col>
<el-col :span="4" class="el-col"> <el-col :span="4" class="el-col">
<div class="text item"> <div class="text item">
<el-checkbox v-model="inputQuery.secCheckChange" :disabled="!inputQuery.secCheckEnable"></el-checkbox> <el-checkbox v-model="inputQuery.secCheckChange" :disabled="!inputQuery.secCheckEnable">
</el-checkbox>
</div> </div>
</el-col> </el-col>
</el-row> </el-row>

@ -71,7 +71,7 @@
></el-input> ></el-input>
</el-form-item> </el-form-item>
<el-form-item class="query-form-item"> <el-form-item class="query-form-item">
<el-select v-model="thirdSysFk" placeholder="请设置主系统"> <el-select v-model="thirdSysFk" placeholder="请设置主系统" disabled>
<el-option <el-option
v-for="item in thirdSys" v-for="item in thirdSys"
:key="item.value" :key="item.value"

@ -184,7 +184,7 @@
<el-button type="text" size="small" <el-button type="text" size="small"
@click.native.stop="deleteCompanyProductRelevance(scope.row)" @click.native.stop="deleteCompanyProductRelevance(scope.row)"
> >
</el-button> </el-button>
</template> </template>
</el-table-column> </el-table-column>

@ -0,0 +1,451 @@
<template>
<div>
<el-card>
<el-form :inline="true" :model="query" class="query-form" size="mini">
<el-form-item class="query-form-item">
<el-input
v-model="query.code"
clearable
placeholder="仓位货位码"
style="width: 400px"
></el-input>
</el-form-item>
<el-form-item class="query-form-item">
<el-select v-model="query.advanceType" placeholder="是否寄售" clearable>
<el-option label="全部" value=""></el-option>
<el-option label="是" value=true></el-option>
<el-option label="否" value=false></el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-button-group>
<el-button type="primary" icon="el-icon-refresh" @click="onReset"></el-button>
<el-button type="primary" icon="search" @click="getList"></el-button>
<el-button type="primary" @click.native="handleForm(null, null)"
>添加仓位
</el-button
>
</el-button-group>
</el-form-item>
</el-form>
<el-table
:data="mergeList"
style="width: 100%;margin-bottom: 20px;"
row-key="id"
border
default-expand-all
:tree-props="{children: 'children', hasChildren: 'hasChildren'}">
<el-table-column
prop="code"
label="仓位货位码"
>
</el-table-column>
<el-table-column
prop="name"
label="仓位货位名称"
>
</el-table-column>
<el-table-column
prop="advanceType"
label="是否寄售">
<template slot-scope="scope">
<span>{{ enableMap[scope.row.advanceType] }}</span>
</template>
</el-table-column>
<el-table-column
prop="isDefault"
label="是否默认库存">
<template slot-scope="scope">
<span>{{ enableMap[scope.row.isDefault] }}</span>
</template>
</el-table-column>
<el-table-column label="操作" fixed="right">
<template slot-scope="scope">
<el-button
type="text"
size="small"
:disabled="scope.row.pid!=0"
@click.native.stop="handleForm(node, scope.row, 'add')"
>添加
</el-button
>
<el-button
type="text"
size="small"
@click.native.stop="handleForm(node, scope.row, 'edit')"
>编辑
</el-button
>
<el-button
type="text"
size="small"
@click.native.stop="handleDel(node,scope.row)"
>删除
</el-button
>
</template>
</el-table-column>
</el-table>
<!-- <el-tree-->
<!-- :data="mergeList"-->
<!-- :props="defaultProps"-->
<!-- node-key="id"-->
<!-- style="width: 50%"-->
<!-- default-expand-all-->
<!-- :expand-on-click-node="false"-->
<!-- :render-content="renderContent"-->
<!-- >-->
<!-- </el-tree>-->
</el-card>
<!--表单界面-->
<el-dialog
:title="formMap[formName]"
:close-on-click-modal="false"
:close-on-press-escape="false"
:visible.sync="formVisible"
:before-close="hideForm"
width="85%"
top="5vh"
>
<el-form :model="formData" :rules="formRules" ref="dataForm">
<el-form-item label="父ID" prop="pid">
<el-select v-model="formData.pid" placeholder="顶级">
<el-option
v-for="item in treeList"
:key="item.id"
:label="item.name"
:value="item.id"
>
<span style="float: left"
><span v-html="item.html"></span>{{ item.title }}</span
>
</el-option>
</el-select>
</el-form-item>
<el-form-item label="仓库货位名称" prop="name">
<el-input
type=""
v-model="formData.name"
auto-complete="off"
></el-input>
</el-form-item>
<el-form-item label="仓库货位代码" prop="title">
<el-input
type=""
v-model="formData.code"
auto-complete="off"
></el-input>
</el-form-item>
<el-form-item label="状态" prop="status">
<el-radio-group v-model="formData.status">
<el-radio :label="0">禁用</el-radio>
<el-radio :label="1">正常</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item>
<el-row :gutter="20" class="el-row" type="flex">
<el-col :span="4" class="el-col">
<div class="text item">
<el-checkbox v-model="formData.advanceType"></el-checkbox>
</div>
</el-col>
<el-col :span="4" class="el-col">
<div class="text item">
<el-checkbox v-model="formData.isDefault"></el-checkbox>
</div>
</el-col>
</el-row>
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button @click.native="hideForm">取消</el-button>
<el-button
type="primary"
@click.native="formSubmit()"
:loading="formLoading"
>提交
</el-button
>
</div>
</el-dialog>
</div>
</template>
<script>
import {
filterList,
saveWarehouse,
deleteWarehouse
} from "../../api/basic/invWarehouse";
const formJson = {
id: null,
pid: null,
name: null,
code: null,
status: 1,
advanceType: false,
isDefault: false
};
export default {
data() {
return {
query: {
id: null,
pid: null,
name: null,
code: null,
status: null,
advanceType: null,
isDefault: null
},
mergeList: [],
node: null,
defaultProps: {
children: "children",
label: "name"
},
treeList: [],
loading: true,
index: null,
formName: null,
formMap: {
add: "新增",
edit: "编辑"
},
enableMap: {
true: "是",
false: "否",
},
formLoading: false,
formVisible: false,
formData: formJson,
formRules: {
name: [
{required: true, message: "请输入仓库货位名", trigger: "blur"}
],
code: [
{required: true, message: "请输入仓库货位代码", trigger: "blur"}
]
},
pidData: {}
,
deleteLoading: false
}
;
},
methods: {
/*eslint-disable */
renderContent(h, {node, data, store}) {
return (
<span
style="flex: 1; display: flex; align-items: center; justify-content: space-between; font-size: 14px; padding-right: 8px;">
<span>
<span title={data.name} style="margin-left:8px">{node.label}</span>
<span style="margin-left:18px">(编码{data.code})</span>
</span>
<span>
<el-button
style="font-size: 12px;"
type="text"
on-click={() => this.handleForm(node, data, "add")}
>
添加货位
</el-button>
<el-button
style="font-size: 12px;"
type="text"
on-click={() => this.handleForm(node, data, "edit")}
>
编辑
</el-button>
<el-button
style="font-size: 12px;"
type="text"
on-click={() => this.handleDel(node, data)}
>
删除
</el-button>
</span>
</span>
);
},
onReset() {
this.$router.push({
path: "",
});
this.query = {
name: "",
status: "",
};
this.getList();
},
onSubmit() {
this.getList();
},
getList() {
this.loading = true;
filterList(this.query)
.then((response) => {
this.loading = false;
this.mergeList = response.data.list || [];
this.treeList = response.data.tree_list || [];
})
.catch(() => {
this.loading = false;
this.mergeList = [];
this.treeList = [];
});
},
//
resetForm() {
if (this.$refs["dataForm"]) {
//
this.$refs["dataForm"].clearValidate();
//
this.$refs["dataForm"].resetFields();
this.getList();
}
},
//
hideForm() {
//
this.formVisible = !this.formVisible;
return true;
},
//
handleForm(node, data, formName) {
this.formVisible = true;
this.pidData = data || null;
formJson.pid = (data && parseInt(data.id)) || "";
this.formData = JSON.parse(JSON.stringify(formJson));
if (formName === "edit") {
this.formData = Object.assign({}, data);
this.node = node;
}
this.formData.pid = !this.formData.pid ? "" : this.formData.pid;
this.formName = formName;
if (data && data.id) {
this.index = this.mergeList.findIndex((d) => d.id === data.id);
}
},
formSubmit() {
this.$refs["dataForm"].validate((valid) => {
if (valid) {
this.formLoading = true;
let data = Object.assign({}, this.formData);
saveWarehouse(data, this.formName)
.then((response) => {
this.formLoading = false;
if (response.code !== 20000) {
this.$message.error(response.message);
return false;
}
this.$message.success("操作成功");
this.formVisible = false;
if (this.formName !== "edit") {
if (response.data && response.data.id) {
data.id = response.data.id;
if (this.pidData) {
if (!this.pidData.children) {
this.$set(this.pidData, "children", []);
}
this.pidData.children.push(data);
} else {
this.mergeList.push(data);
}
}
} else {
const parent = this.node.parent;
const children = parent.data.children || parent.data;
const index = children.findIndex((d) => d.id === data.id);
children.splice(index, 1, data);
}
//
this.resetForm();
this.getList();
})
.catch(() => {
this.formLoading = false;
});
}
});
},
//
handleDel(node, data) {
if (data.children && data.children.length > 0) {
this.$alert("请先删除子节点", "提示", {
confirmButtonText: "确定",
});
return false;
}
if (data.id) {
this.$confirm("确认删除该记录吗?", "提示", {
type: "warning",
})
.then(() => {
this.deleteLoading = true;
let para = {id: data.id};
deleteWarehouse(para)
.then((response) => {
this.deleteLoading = false;
if (response.code !== 20000) {
this.$message.error(response.message);
return false;
}
this.$message.success("删除成功");
const parent = node.parent;
const children = parent.data.children || parent.data;
const index = children.findIndex((d) => d.id === data.id);
children.splice(index, 1);
})
.catch(() => {
this.deleteLoading = false;
});
})
.catch(() => {
this.$message.info("取消删除");
});
}
},
},
filters: {
statusFilterType(status) {
const statusMap = {
0: "gray",
1: "success",
};
return statusMap[status];
},
statusFilterName(status) {
const statusMap = {
0: "禁用",
1: "正常",
};
return statusMap[status];
},
},
mounted() {
},
created() {
//
this.getList();
},
};
</script>
<style type="text/scss" lang="scss">
</style>

@ -22,16 +22,20 @@
></el-input> ></el-input>
</el-form-item> </el-form-item>
<el-form-item class="query-form-item"> <el-form-item class="query-form-item">
<el-select v-model="filterQuery.billAction" placeholder="请选择业务类型" clearable="true">
<el-option <el-select v-model="filterQuery.billAction" placeholder="请选择第三方系统单据类型" clearable="true">
v-for="item in originTypes" <el-option
:key="item.name" v-for="item in originTypes"
:label="item.name" :key="item.name"
:value="item.action"> :label="item.name"
<span style="float: left">{{ item.name }}</span> :value="item.action">
<!--<span style="float: right; color: #8492a6; font-size: 13px">{{ item.action }}</span>--> <span style="float: left;font-size: 13px">{{ item.name }}</span>
</el-option> <span style="float: right; color: #8492a6; font-size: 13px;margin-left: 10px">{{
</el-select> item.thirdSysName
}}</span>
</el-option>
</el-select>
</el-form-item> </el-form-item>
<el-form-item class="query-form-item"> <el-form-item class="query-form-item">
<span style="color: #000; margin-left: 10px; margin-right: 6px">单据日期:</span> <span style="color: #000; margin-left: 10px; margin-right: 6px">单据日期:</span>

@ -26,7 +26,7 @@
@row-click="moduleClick" highlight-current-row @row-click="moduleClick" highlight-current-row
> >
<el-table-column type="index" label="序号" width="50"></el-table-column> <el-table-column type="index" label="序号" width="50"></el-table-column>
<el-table-column label="模板类型" width="150" prop="templateType" > <el-table-column label="模板类型" width="150" prop="templateType">
<template slot-scope="scope"> <template slot-scope="scope">
{{ moduleTypeMap[scope.row.templateType] }} {{ moduleTypeMap[scope.row.templateType] }}
</template> </template>
@ -91,6 +91,66 @@
> >
</el-pagination> </el-pagination>
</el-card> </el-card>
<el-card class="el-card">
<el-table v-loading="loading" :data="list" style="width: 100%">
<el-table-column label="序号" type="index" show-overflow-tooltip="true"></el-table-column>
<el-table-column label="业务类型" prop="localActionName" show-overflow-tooltip="true"></el-table-column>
<el-table-column label="模板名称">
<template slot-scope="scope">
<p v-if="scope.row.templateName === null">
<el-button
type="primary"
size="mini"
@click.native.stop="busSelectTemplate(scope.row)"
>选择模板
</el-button
>
</p>
<p v-if="scope.row.templateName !== null">
<el-button
type="primary"
size="mini"
@click.native.stop="busSelectTemplate(scope.row)"
>{{ scope.row.templateName }}
</el-button
>
</p>
</template>
</el-table-column>
</el-table>
<el-dialog
title="接口参数设置"
:close-on-click-modal="false"
:close-on-press-escape="false"
:visible.sync="modifyDetailDialogVisible"
width="70%"
v-if="modifyDetailDialogVisible"
>
<modifyDetailDialog :inputDetailQuery="inputDetailQuery"></modifyDetailDialog>
<div style="text-align: center">
<el-button type="primary" size="small" icon="search" @click="onDetailModifySubmit"
>提交
</el-button
>
<el-button type="primary" size="small" icon="search" @click="cancelDialog"
>取消
</el-button
>
</div>
</el-dialog>
<el-pagination
:page-size="moduleQuery.limit"
@current-change="handlePageChange"
layout="prev, pager, next"
:total="total"
></el-pagination>
<div style="margin-top: 18px ; color: #F71616;">
<span>重要提示本页功能仅供技术提供方修改&nbsp;</span>
</div>
</el-card>
<!--表单--> <!--表单-->
<el-dialog <el-dialog
:title="formMap[formName]" :title="formMap[formName]"
@ -288,8 +348,8 @@ import {
systemPDFTemplateSave, systemPDFTemplateSave,
systemPDFTemplateDeleteById, systemPDFTemplateDeleteById,
systemPDFModuleList, systemPDFModuleList,
systemPDFModuleSave, systemPDFModuleSave, updateDetailRel,
getSystemPDFModules getSystemPDFModules, moduleDetail
} from "../../../api/param/systemPDFTemplate"; } from "../../../api/param/systemPDFTemplate";
import {saveAs} from 'file-saver'; import {saveAs} from 'file-saver';
import {BASE_URL, SERVER_IP} from "../../../config/app"; import {BASE_URL, SERVER_IP} from "../../../config/app";
@ -314,6 +374,8 @@ export default {
data() { data() {
return { return {
query: { query: {
templateType: null,
moduleId: null,
name: "", name: "",
page: 1, page: 1,
limit: 20 limit: 20
@ -330,6 +392,7 @@ export default {
moduleNameList: [], moduleNameList: [],
moduleTotal: 0, moduleTotal: 0,
selectTemplateQuery: { selectTemplateQuery: {
busRlId: null,
name: "", name: "",
module: null, module: null,
page: 1, page: 1,
@ -346,7 +409,7 @@ export default {
}, },
moduleSelectList: [], moduleSelectList: [],
moduleSelectTotal: 0, moduleSelectTotal: 0,
loading: true, loading: false,
index: null, index: null,
formName: null, formName: null,
moduleFormName: null, moduleFormName: null,
@ -382,6 +445,8 @@ export default {
path: "" path: ""
}); });
this.query = { this.query = {
templateType: null,
moduleId: null,
name: "", name: "",
page: 1, page: 1,
limit: 20 limit: 20
@ -400,23 +465,22 @@ export default {
this.getModuleList(); this.getModuleList();
}, },
getList() { getList() {
this.loading = true; // this.loading = true;
systemPDFTemplateList(this.query) moduleDetail(this.query)
.then(response => { .then(response => {
this.loading = false; this.loading = false;
this.list = response.data.list || []; this.list = response.data || [];
this.total = response.data.total || 0;
}) })
.catch(() => { .catch(() => {
this.loading = false; this.loading = false;
this.list = []; this.list = [];
this.total = 0;
}); });
}, },
moduleClick(row) { moduleClick(row) {
this.query = { this.query = {
module: row.id, templateType: row.templateType,
moduleId: row.id,
page: 1, page: 1,
limit: 20 limit: 20
}; };
@ -490,13 +554,34 @@ export default {
}; };
this.moduleFormVisible = true; this.moduleFormVisible = true;
this.selectTemplateQuery = { this.selectTemplateQuery = {
module:row.templateType, module: row.templateType,
name: "", name: "",
page: 1, page: 1,
limit: 20 limit: 20
}; };
this.selectTemplateGetList(); this.selectTemplateGetList();
}, },
busSelectTemplate(row) {
this.moduleFormData = {
id: row.id,
templateId: row.templateId,
};
this.moduleFormVisible = true;
this.selectTemplateQuery = {
module: row.templateType,
busRlId: row.id,
type: 1,
name: "",
page: 1,
limit: 20
};
console.log("this.selectTemplateQuery.busRlId =" + this.selectTemplateQuery.busRlId);
this.selectTemplateGetList();
},
selectTemplateGetList() { selectTemplateGetList() {
console.log(this.selectTemplateQuery) console.log(this.selectTemplateQuery)
this.selectTemplateLoading = true; this.selectTemplateLoading = true;
@ -689,29 +774,50 @@ export default {
this.moduleFormLoading = true; this.moduleFormLoading = true;
let data = Object.assign({}, this.moduleFormData); let data = Object.assign({}, this.moduleFormData);
this.moduleFormName = 'update'; this.moduleFormName = 'update';
systemPDFModuleSave(data, this.moduleFormName) if (this.selectTemplateQuery.type == 1) {
.then(response => {
this.moduleFormLoading = false;
if (response.code !== 20000) { console.log("this.selectTemplateQuery.busRlId =" + this.selectTemplateQuery.busRlId);
this.$message.error(response.message); let query = {
return false; id: this.selectTemplateQuery.busRlId,
} templateId: data.templateId,
this.$message.success("操作成功"); }
this.moduleFormVisible = false; updateDetailRel(query)
if (this.moduleFormName === "add") { .then(response => {
// this.moduleFormVisible = false;
if (response.data && response.data.id) { this.moduleFormLoading = false;
data.id = response.data.id; if (response.code !== 20000) {
this.moduleList.unshift(data); this.$message.error(response.message);
return false;
} }
} else { this.getList();
this.moduleList.splice(this.index, 1, data); }).catch(() => {
}
this.getModuleList();
})
.catch(() => {
this.moduleFormLoading = false; this.moduleFormLoading = false;
}); });
} else
systemPDFModuleSave(data, this.moduleFormName)
.then(response => {
this.moduleFormLoading = false;
if (response.code !== 20000) {
this.$message.error(response.message);
return false;
}
this.$message.success("操作成功");
this.moduleFormVisible = false;
if (this.moduleFormName === "add") {
//
if (response.data && response.data.id) {
data.id = response.data.id;
this.moduleList.unshift(data);
}
} else {
this.moduleList.splice(this.index, 1, data);
}
this.getModuleList();
})
.catch(() => {
this.moduleFormLoading = false;
});
}, },
getPDFModuleNameList() { getPDFModuleNameList() {
getSystemPDFModules() getSystemPDFModules()

@ -181,6 +181,54 @@
</el-col> </el-col>
</el-row> </el-row>
<el-row :gutter="20" v-if="registerConfigMap.companyCheckStatus">
<el-col :span="4">
<div class="register-text">
<span>阳光采购平台企业名称:&nbsp;</span>
</div>
</el-col>
<el-col :span="10">
<el-form-item prop="fromCorp">
<el-select
v-model="inputQuery.udplatCompanyName"
filterable
remote
clearable="true"
reserve-keyword
placeholder="请输入阳光采购企业名称"
:remote-method="findUdplatMethod"
size="small"
style="width: 100%"
@change="selectUdlpatOne"
:loading="loading"
>
<el-option
v-for="item in fromUdplatOptions"
:key="item.name"
:label="item.name"
:value="item"
>
<span style="float: left">{{ item.name }}</span>
</el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="3">
<!--<el-button-->
<!--type="primary"-->
<!--size="small"-->
<!--icon="search"-->
<!--style="margin-top: 0.5px"-->
<!--@click="checkCompanyName"-->
<!--&gt;-->
<!--校验企业名称-->
<!--</el-button>-->
</el-col>
</el-row>
<!-- <el-row :gutter="20">--> <!-- <el-row :gutter="20">-->
<!-- <el-col :span="4">--> <!-- <el-col :span="4">-->
<!-- <div class="register-text">--> <!-- <div class="register-text">-->
@ -418,7 +466,7 @@
<el-col :span="10" class="el-col" type="flex"> <el-col :span="10" class="el-col" type="flex">
<div class="text item"> <div class="text item">
<span>{{this.acoountInfo }}</span> <span>{{ this.acoountInfo }}</span>
</div> </div>
</el-col> </el-col>
<el-col :span="10" class="el-col" type="flex"> <el-col :span="10" class="el-col" type="flex">
@ -444,340 +492,370 @@
</template> </template>
<script> <script>
import { import {
getCompany, getCompany,
modifyCompany, modifyCompany,
getRefid, checkCompany, getRegisterConfig, getRefid, checkCompany, getRegisterConfig,
} from "../../api/warehouse/company"; } from "../../api/warehouse/company";
import {getCheckcode, register} from "../../api/auth/register"; import {getCheckcode, register} from "../../api/auth/register";
import { import {
provinceAndCityData, provinceAndCityData,
regionData, regionData,
provinceAndCityDataPlus, provinceAndCityDataPlus,
regionDataPlus, regionDataPlus,
CodeToText, CodeToText,
TextToCode, TextToCode,
} from "element-china-area-data"; } from "element-china-area-data";
import Clipboard from 'clipboard' import Clipboard from 'clipboard'
import {BASE_URL} from "../../config/app"; import {BASE_URL} from "../../config/app";
import {getBasicUnitMaintains} from "../../api/basic/basicUnitMaintain" import {getBasicUnitMaintains} from "../../api/basic/basicUnitMaintain"
import {getCorps} from "@/api/thrsys/thrCorps";
export default {
data() {
let validatePass2 = (rule, value, callback) => { export default {
if (value === "") { data() {
callback(new Error("请再次输入密码")); let validatePass2 = (rule, value, callback) => {
} else if (value !== this.inputQuery.password) { if (value === "") {
callback(new Error("两次输入密码不一致!")); callback(new Error("请再次输入密码"));
} else if (value !== this.inputQuery.password) {
callback(new Error("两次输入密码不一致!"));
} else {
callback();
}
};
return {
inputQuery: {
nickName: null,
password: "",
realName: "",
tel: "",
mobile: "",
userId: "",
confirmPassword: "",
checkCode: "",
email: "",
companyId: "",
companyName: "",
udplatCompanyName: "",
udplatCompanyId: null,
creditNum: "",
area: "",
areaCode: "",
detailAddr: "",
bussinessStatus: "2",
checkCompanyNameStatus: false,
licenseUrl: null,
},
uploadUrl: null,
fileUrl: null,
isTimer: false,
btnTitle: "获取验证码",
options: regionDataPlus,
selectedOptions: [],
fromOptions: [],
fromUdplatOptions: [],
acoountInfo: "账号:" + "------" + "\n密码" + "-----",
rules: {
nickName: [
{required: true, message: "请输入用户名称", trigger: "blur"},
],
password: [{required: true, message: "请输入密码", trigger: "blur"}],
realName: [
{required: true, message: "请输入负责人姓名", trigger: "blur"},
],
tel: [{required: true, message: "请输入联系电话", trigger: "blur"},
// { pattern:/^((0\d{2,3}-\d{7,8})|(1[3584]\d{9}))$/, message: "", trigger: "blur" }
],
mobile: [{required: true, message: "请输入手机号码", trigger: "blur"},
// { pattern:/^0{0,1}(13[0-9]|15[7-9]|153|156|18[7-9])[0-9]{8}$/, message: "", trigger: "blur" }
],
confirmPassword: [
{required: true, message: "请确认密码", trigger: "blur"},
{validator: validatePass2, trigger: "blur"},
],
checkCode: [
{required: true, message: "请输入手机验证码", trigger: "blur"},
],
email: [{required: true, message: "请输入邮箱", trigger: "blur"}],
companyName: [
{required: true, message: "请输入企业名称", trigger: "blur"},
],
udplatCompanyName: [
{required: true, message: "请输入阳光采购平台企业名称", trigger: "blur"},
],
creditNum: [
{required: true, message: "请输入统一社会信用号", trigger: "blur"},
],
area: [{required: true, message: "请选择所属地区", trigger: "blur"}],
detailAddr: [
{required: true, message: "请输入详细地址", trigger: "blur"},
],
bussinessStatus: [
{required: true, message: "请选择企业类型", trigger: "blur"},
],
},
registerConfigMap: {
companyCheckStatus: true
},
formVisible: false,
formData: {
account: "",
password: "",
}
};
},
created() {
this.registerConfig();
this.uploadUrl = BASE_URL + "/udiwms/upload/register/file";
this.fileUrl = BASE_URL + "/udiwms/image/register/file/getImage?type=image1&name=";
// this.getData();
},
methods: {
onSubmit(formName) {
// this.formVisible = true;
this.$refs[formName].validate((valid) => {
if (valid) {
// if (!this.checkCompanyNameStatus && this.registerConfigMap.companyCheckStatus) {
// return this.$message.error('');
// }
this.loading = true;
register(this.inputQuery).then((response) => {
if (response.code === 20000) {
this.loading = false;
this.formData = {
account: response.data,
password: this.inputQuery.password,
}
this.formVisible = true;
this.acoountInfo = "账号:" + this.formData.account + "\n密码" + this.formData.password;
} else {
this.$message.error(response.message);
}
});
} else { } else {
callback(); console.log("error submit!!");
return false;
} }
});
},
formDefine() {
this.formVisible = false;
this.$router.push({path: "../login"});
},
getData() {
this.loading = true;
getCompany().then((response) => {
this.loading = false;
this.inputQuery = response.data;
this.inputQuery.bussinessStatus = "2";
console.log(this.inputQuery)
this.selectedOptions = this.inputQuery.areaCode.split(",");
});
},
getCheckCode(mobile) {
let tquery = {
phoneNum: this.inputQuery.mobile,
}; };
return { getCheckcode(tquery).then((response) => {
inputQuery: { if (response.code === 20000) {
nickName: null, this.validateBtn();
password: "", } else {
realName: "", this.$message.error(response.message);
tel: "",
mobile: "",
userId: "",
confirmPassword: "",
checkCode: "",
email: "",
companyId: "",
companyName: "",
creditNum: "",
area: "",
areaCode: "",
detailAddr: "",
bussinessStatus: "2",
checkCompanyNameStatus: false,
licenseUrl: null,
},
uploadUrl: null,
fileUrl: null,
isTimer: false,
btnTitle: "获取验证码",
options: regionDataPlus,
selectedOptions: [],
fromOptions: [],
acoountInfo: "账号:" + "------" + "\n密码" + "-----",
rules: {
nickName: [
{required: true, message: "请输入用户名称", trigger: "blur"},
],
password: [{required: true, message: "请输入密码", trigger: "blur"}],
realName: [
{required: true, message: "请输入负责人姓名", trigger: "blur"},
],
tel: [{required: true, message: "请输入联系电话", trigger: "blur"},
// { pattern:/^((0\d{2,3}-\d{7,8})|(1[3584]\d{9}))$/, message: "", trigger: "blur" }
],
mobile: [{required: true, message: "请输入手机号码", trigger: "blur"},
// { pattern:/^0{0,1}(13[0-9]|15[7-9]|153|156|18[7-9])[0-9]{8}$/, message: "", trigger: "blur" }
],
confirmPassword: [
{required: true, message: "请确认密码", trigger: "blur"},
{validator: validatePass2, trigger: "blur"},
],
checkCode: [
{required: true, message: "请输入手机验证码", trigger: "blur"},
],
email: [{required: true, message: "请输入邮箱", trigger: "blur"}],
companyName: [
{required: true, message: "请输入企业名称", trigger: "blur"},
],
creditNum: [
{required: true, message: "请输入统一社会信用号", trigger: "blur"},
],
area: [{required: true, message: "请选择所属地区", trigger: "blur"}],
detailAddr: [
{required: true, message: "请输入详细地址", trigger: "blur"},
],
bussinessStatus: [
{required: true, message: "请选择企业类型", trigger: "blur"},
],
},
registerConfigMap: {
companyCheckStatus: true
},
formVisible: false,
formData: {
account: "",
password: "",
} }
});
},
checkCompanyName() {
if (this.$isBlank(this.inputQuery.companyName)) {
this.$message.error('企业名称不能为空');
return;
}
let tQuery = {
companyName: this.inputQuery.companyName,
}; };
checkCompany(tQuery).then((response) => {
if (response.code === 20000) {
this.checkCompanyNameStatus = true;
this.$message.success("校验成功!");
} else {
this.$message.error(response.message);
}
});
}, },
created() { registerConfig() {
this.registerConfig(); getRegisterConfig().then((response) => {
this.uploadUrl = BASE_URL + "/udiwms/upload/register/file"; if (response.code === 20000) {
this.fileUrl = BASE_URL + "/udiwms/image/register/file/getImage?type=image1&name="; this.registerConfigMap = response.data;
// this.getData(); }
});
}, },
methods: { validateBtn() {
onSubmit(formName) { //
// this.formVisible = true; let time = 60;
this.$refs[formName].validate((valid) => { let timer = setInterval(() => {
if (valid) { if (time === 0) {
// if (!this.checkCompanyNameStatus && this.registerConfigMap.companyCheckStatus) { clearInterval(timer);
// return this.$message.error(''); this.isTimer = false;
// } this.btnTitle = "获取验证码";
this.loading = true; } else {
register(this.inputQuery).then((response) => { this.btnTitle = time + "秒后重试";
if (response.code === 20000) { this.isTimer = true;
this.loading = false; time--;
this.formData = {
account: response.data,
password: this.inputQuery.password,
}
this.formVisible = true;
this.acoountInfo = "账号:" + this.formData.account + "\n密码" + this.formData.password;
} else {
this.$message.error(response.message);
}
});
} else {
console.log("error submit!!");
return false;
}
});
},
formDefine() {
this.formVisible = false;
this.$router.push({path: "../login"});
},
getData() {
this.loading = true;
getCompany().then((response) => {
this.loading = false;
this.inputQuery = response.data;
this.inputQuery.bussinessStatus = "2";
console.log(this.inputQuery)
this.selectedOptions = this.inputQuery.areaCode.split(",");
});
},
getCheckCode(mobile) {
let tquery = {
phoneNum: this.inputQuery.mobile,
};
getCheckcode(tquery).then((response) => {
if (response.code === 20000) {
this.validateBtn();
} else {
this.$message.error(response.message);
}
});
},
checkCompanyName() {
if (this.$isBlank(this.inputQuery.companyName)) {
this.$message.error('企业名称不能为空');
return;
} }
let tQuery = { }, 1000);
companyName: this.inputQuery.companyName, },
}; handleChange(value) {
checkCompany(tQuery).then((response) => { this.inputQuery.area =
if (response.code === 20000) { CodeToText[value[0]] + CodeToText[value[1]] + CodeToText[value[2]];
this.checkCompanyNameStatus = true; console.log(value + "\n" + this.inputQuery.area);
this.$message.success("校验成功!"); this.inputQuery.areaCode = value.toString();
} else { },
this.$message.error(response.message); copy() {
}
}); let sel = this;
}, var clipboard = new Clipboard('.tag-read')
registerConfig() { clipboard.on('success', e => {
getRegisterConfig().then((response) => { console.log('复制成功')
if (response.code === 20000) { //
this.registerConfigMap = response.data; clipboard.destroy();
} });
}); clipboard.on('error', e => {
}, //
validateBtn() { console.log('该浏览器不支持复制')
// //
let time = 60; clipboard.destroy()
let timer = setInterval(() => { });
if (time === 0) { this.$confirm("账号密码复制成功!是否跳转登录", "提示", {
clearInterval(timer); confirmButtonText: "确定",
this.isTimer = false; cancelButtonText: "取消",
this.btnTitle = "获取验证码"; type: "warning",
} else { }).then(() => {
this.btnTitle = time + "秒后重试"; // this.formVisible = false;
this.isTimer = true; // this.$router.push({path: "../login"});
time--; sel.formDefine();
} }).catch(() => {
}, 1000); });
}, },
handleChange(value) { selectOne(event) {
this.inputQuery.area = this.inputQuery.companyName = event.name;
CodeToText[value[0]] + CodeToText[value[1]] + CodeToText[value[2]]; this.inputQuery.companyId = event.erpId;
console.log(value + "\n" + this.inputQuery.area); },
this.inputQuery.areaCode = value.toString();
}, selectUdlpatOne(event) {
copy() { this.inputQuery.udplatCompanyName = event.name;
this.inputQuery.udplatCompanyId = event.erpId;
let sel = this; },
var clipboard = new Clipboard('.tag-read')
clipboard.on('success', e => { findMethod(query) {
console.log('复制成功') console.log(query);
// this.fromOptions = [];
clipboard.destroy(); let cQuery = {
}); key: query,
clipboard.on('error', e => {
// };
console.log('该浏览器不支持复制') getBasicUnitMaintains(cQuery)
// .then((response) => {
clipboard.destroy() this.loading = false;
}); this.fromOptions = response.data.page.list || [];
this.$confirm("账号密码复制成功!是否跳转登录", "提示", { })
confirmButtonText: "确定", .catch(() => {
cancelButtonText: "取消", this.loading = false;
type: "warning",
}).then(() => {
// this.formVisible = false;
// this.$router.push({path: "../login"});
sel.formDefine();
}).catch(() => {
}); });
}, },
selectOne(event) {
this.inputQuery.companyName = event.name; findUdplatMethod(query) {
this.inputQuery.companyId = event.erpId; console.log(query);
// console.log("this.inputQuery.companyId" + item); this.fromUdplatOptions = [];
console.log("this.inputQuery.companyId" + event.erpId); let cQuery = {
}, name: query,
findMethod(query) { thirdSysFk: null,
console.log(query); };
this.fromOptions = []; getCorps(cQuery)
let cQuery = { .then((response) => {
key: query, this.loading = false;
}; this.fromUdplatOptions = response.data.list || [];
getBasicUnitMaintains(cQuery) })
.then((response) => { .catch(() => {
this.loading = false; this.loading = false;
this.fromOptions = response.data.page.list || []; });
}) },
.catch(() => { uploadHandleRemove(file, fileList) {
this.loading = false; console.log(file, fileList);
}); },
}, uploadHandlePreview(file) {
uploadHandleRemove(file, fileList) { console.log(file);
console.log(file, fileList); console.log(this.fileList);
}, },
uploadHandlePreview(file) { uploadHandleExceed(files, fileList) {
console.log(file); this.$message.warning(`当前限制选择 1 个文件,本次选择了 ${files.length} 个文件,共选择了 ${files.length + fileList.length} 个文件`);
console.log(this.fileList); },
}, uploadOnchange(file, fileList) {
uploadHandleExceed(files, fileList) { let fileName = file.name;
this.$message.warning(`当前限制选择 1 个文件,本次选择了 ${files.length} 个文件,共选择了 ${files.length + fileList.length} 个文件`); let uid = file.uid
}, let pos = fileName.lastIndexOf(".");
uploadOnchange(file, fileList) { let lastName = fileName.substring(pos, fileName.length);
let fileName = file.name; if (lastName.toLowerCase() !== ".jpg" && lastName.toLowerCase() !== ".png") {
let uid = file.uid this.$message.error("上传文件只能是 .jpg,.png 格式");
let pos = fileName.lastIndexOf("."); for (let i = 0; i < fileList.length; i++) {//list
let lastName = fileName.substring(pos, fileName.length); if (fileList[i].uid === uid) {
if (lastName.toLowerCase() !== ".jpg" && lastName.toLowerCase() !== ".png") { fileList.splice(i, 1)
this.$message.error("上传文件只能是 .jpg,.png 格式");
for (let i = 0; i < fileList.length; i++) {//list
if (fileList[i].uid === uid) {
fileList.splice(i, 1)
}
} }
return;
} }
// return;
const isLt = file.size / 1024 / 1024 / 2 <= 1; }
if (!isLt) { //
this.$message.error("上传文件大小不能超过 2MB"); const isLt = file.size / 1024 / 1024 / 2 <= 1;
for (let i = 0; i < fileList.length; i++) { if (!isLt) {
if (fileList[i].uid === uid) { this.$message.error("上传文件大小不能超过 2MB");
fileList.splice(i, 1) for (let i = 0; i < fileList.length; i++) {
} if (fileList[i].uid === uid) {
fileList.splice(i, 1)
} }
} }
return isLt; }
}, return isLt;
uploadHandleSuccess(response, file, fileList) { },
console.log(response) uploadHandleSuccess(response, file, fileList) {
if (response.code === 20000) { console.log(response)
this.inputQuery.licenseUrl = response.data.name; if (response.code === 20000) {
} else { this.inputQuery.licenseUrl = response.data.name;
this.$message.error("文件上传失败:" + response.message); } else {
} this.$message.error("文件上传失败:" + response.message);
}, }
uploadHandleError() { },
}, uploadHandleError() {
openFile(path) {
window.open(this.fileUrl + path);
},
}, },
}; openFile(path) {
window.open(this.fileUrl + path);
},
},
};
</script> </script>
<style> <style>
.register-text { .register-text {
width: 100%; width: 100%;
font-size: 13px; font-size: 13px;
font-family: "Microsoft YaHei"; font-family: "Microsoft YaHei";
float: right; float: right;
text-align: right; text-align: right;
margin-top: 10px; margin-top: 10px;
} }
.el-card { .el-card {
margin-right: 20px; margin-right: 20px;
margin-top: 15px; margin-top: 15px;
/*transition: all .5s;*/ /*transition: all .5s;*/
} }
.el-row { .el-row {
display: flex; display: flex;
flex-wrap: wrap; flex-wrap: wrap;
} }
.el-col { .el-col {
border-radius: 4px; border-radius: 4px;
flex-wrap: wrap; flex-wrap: wrap;
} }
</style> </style>

@ -327,7 +327,7 @@
<el-button <el-button
type="text" type="text"
size="small" size="small"
:disabled="scope.row.bindStatus === 0 " :disabled="scope.row.bindRlFk != null "
@click.native.stop="bindRl(scope.row)" @click.native.stop="bindRl(scope.row)"
>绑定产品 >绑定产品
</el-button </el-button
@ -335,7 +335,7 @@
<el-button <el-button
type="text" type="text"
size="small" size="small"
:disabled="scope.row.bindSupStatus === 0 || scope.row.bindSupStatus ===null" :disabled=" scope.row.supId !=null && scope.row.supId !='MUTI'"
@click.native.stop="handleUnitClick(scope.row)" @click.native.stop="handleUnitClick(scope.row)"
>绑定供应商 >绑定供应商
</el-button </el-button
@ -370,7 +370,8 @@
style="width: 100%" style="width: 100%"
@row-click="selectUnit" @row-click="selectUnit"
> >
<el-table-column label="往来单位ID" prop="unitId"></el-table-column> <el-table-column label="序号" type="index" width="60" fixed></el-table-column>
<el-table-column label="往来单位ID" prop="erpId"></el-table-column>
<el-table-column <el-table-column
label="往来单位名称" label="往来单位名称"
prop="name" prop="name"

@ -668,6 +668,7 @@ export default {
let url = window.URL.createObjectURL( let url = window.URL.createObjectURL(
new Blob(binaryData, {type: "application/json"}) new Blob(binaryData, {type: "application/json"})
); );
// window.open(url);
this.loading = false; this.loading = false;
const eleLink = document.createElement('a'); const eleLink = document.createElement('a');
var timestamp=formatDate(new Date(),"yyyy-MM-dd_hh:mm") var timestamp=formatDate(new Date(),"yyyy-MM-dd_hh:mm")

@ -4,68 +4,92 @@
<div> <div>
<el-form :inline="true" :model="listQuery" style="display: flex;" size="mini"> <el-form :inline="true" :model="listQuery" style="display: flex;" size="mini">
<el-form-item class="query-form-item"> <el-row>
<el-input <el-form-item class="query-form-item">
v-model="listQuery.billNo" <el-input
placeholder="单据号" v-model="listQuery.billNo"
clearable placeholder="单据号"
></el-input> clearable
</el-form-item> ></el-input>
<el-form-item class="query-form-item"> </el-form-item>
<el-input <el-form-item class="query-form-item">
v-model="listQuery.corpName" <el-input
placeholder="往来单位" v-model="listQuery.corpName"
clearable placeholder="往来单位"
></el-input> clearable
</el-form-item> ></el-input>
<el-form-item class="query-form-item"> </el-form-item>
<!-- <el-select v-model="listQuery.billAction" placeholder="请选择业务类型">--> <el-form-item class="query-form-item">
<!-- <el-option--> <!-- <el-select v-model="listQuery.billAction" placeholder="请选择业务类型">-->
<!-- v-for="item in busTypes"--> <!-- <el-option-->
<!-- :key="item.localName"--> <!-- v-for="item in busTypes"-->
<!-- :label="item.localName"--> <!-- :key="item.localName"-->
<!-- :value="item.action">--> <!-- :label="item.localName"-->
<!-- <span style="float: left">{{ item.localName }}</span>--> <!-- :value="item.action">-->
<!-- &lt;!&ndash;<span style="float: right; color: #8492a6; font-size: 13px">{{ item.action }}</span>&ndash;&gt;--> <!-- <span style="float: left">{{ item.localName }}</span>-->
<!-- </el-option>--> <!-- &lt;!&ndash;<span style="float: right; color: #8492a6; font-size: 13px">{{ item.action }}</span>&ndash;&gt;-->
<!-- </el-select>--> <!-- </el-option>-->
<!-- </el-select>-->
<el-select v-model="listQuery.billAction" placeholder="请选择业务类型" clearable="true"> <el-select v-model="listQuery.billAction" placeholder="请选择第三方系统单据类型" clearable="true">
<el-option <el-option
v-for="item in originTypes" v-for="item in originTypes"
:key="item.name" :key="item.name"
:label="item.name" :label="item.name"
:value="item.action"> :value="item.action">
<span style="float: left">{{ item.name }}</span> <span style="float: left;font-size: 13px">{{ item.name }}</span>
<!--<span style="float: right; color: #8492a6; font-size: 13px">{{ item.action }}</span>--> <span style="float: right; color: #8492a6; font-size: 13px;margin-left: 10px">{{
</el-option> item.thirdSysName
</el-select> }}</span>
</el-form-item> </el-option>
<el-form-item class="query-form-item">
</el-select>
</el-form-item>
<!-- <el-form-item class="query-form-item">-->
<!-- <el-select v-model="listQuery.thirdSys" placeholder="请选择第三方系统" @change="thirdSysChange">-->
<!-- <el-option-->
<!-- v-for="item in thirdSys"-->
<!-- :key="item.value"-->
<!-- :label="item.thirdName"-->
<!-- :value="item.thirdId">-->
<!-- <span style="float: left">{{ item.thirdName }}</span>-->
<!-- <span style="float: right; color: #8492a6; font-size: 13px">{{-->
<!-- item.thirdId-->
<!-- }}</span>-->
<!-- </el-option>-->
<!-- </el-select>-->
<!-- </el-form-item>-->
</el-row>
<el-row>
<el-form-item class="query-form-item">
<span style="color: #000; margin-left: 10px; margin-right: 6px" <span style="color: #000; margin-left: 10px; margin-right: 6px"
>单据日期:</span >单据日期:</span
> >
<el-date-picker <el-date-picker
:picker-options="pickerOptions" :picker-options="pickerOptions"
v-model="actDateRange" v-model="actDateRange"
type="daterange" type="daterange"
format="yyyy 年 MM 月 dd 日" format="yyyy 年 MM 月 dd 日"
value-format="yyyy-MM-dd" value-format="yyyy-MM-dd"
range-separator="至" range-separator="至"
start-placeholder="开始日期" start-placeholder="开始日期"
end-placeholder="结束日期" end-placeholder="结束日期"
>
</el-date-picker>
</el-form-item>
<el-form-item style="display: flex">
<el-button-group>
<el-button type="primary" icon="search" @click="getList"></el-button>
<el-button type="primary" icon="search" @click="combine"
>确定
</el-button
> >
</el-button-group> </el-date-picker>
</el-form-item> </el-form-item>
<el-form-item style="display: flex">
<el-button-group>
<el-button type="primary" icon="search" @click="getList"></el-button>
<el-button type="primary" icon="search" @click="combine"
>确定
</el-button
>
</el-button-group>
</el-form-item>
</el-row>
</el-form> </el-form>
<el-table <el-table
:data="dataList" :data="dataList"

@ -242,9 +242,9 @@
</el-table-column> </el-table-column>
<el-table-column width="180" label="生产日期"> <el-table-column width="180" label="生产日期">
<template slot-scope="scope"> <template slot-scope="scope">
<!-- <el-input size="small" v-model="scope.row.productDate"--> <!-- <el-input size="small" v-model="scope.row.productDate"-->
<!-- :disabled="scope.row.index !== selectedIndex"--> <!-- :disabled="scope.row.index !== selectedIndex"-->
<!-- placeholder="请输入生产日期" style="width: 80%"></el-input>--> <!-- placeholder="请输入生产日期" style="width: 80%"></el-input>-->
<el-date-picker <el-date-picker
type="date" type="date"
size="small" v-model="scope.row.productDate" size="small" v-model="scope.row.productDate"
@ -258,9 +258,9 @@
</el-table-column> </el-table-column>
<el-table-column width="180" label="失效日期"> <el-table-column width="180" label="失效日期">
<template slot-scope="scope"> <template slot-scope="scope">
<!-- <el-input size="small" v-model="scope.row.expireDate"--> <!-- <el-input size="small" v-model="scope.row.expireDate"-->
<!-- :disabled="scope.row.index !== selectedIndex"--> <!-- :disabled="scope.row.index !== selectedIndex"-->
<!-- placeholder="请输入失效日期" style="width: 80%"></el-input>--> <!-- placeholder="请输入失效日期" style="width: 80%"></el-input>-->
<el-date-picker <el-date-picker
type="date" type="date"
size="small" v-model="scope.row.expireDate" size="small" v-model="scope.row.expireDate"
@ -624,6 +624,7 @@ export default {
if (this.orderEditor) { if (this.orderEditor) {
this.thisData.orderId = this.formData.id this.thisData.orderId = this.formData.id
} }
this.thisData.stockOrderLists = this.codeArray;
this.selectProductVisible = true; this.selectProductVisible = true;
return; return;
} }
@ -703,6 +704,7 @@ export default {
if (this.orderEditor) { if (this.orderEditor) {
this.thisData.orderId = this.formData.id this.thisData.orderId = this.formData.id
} }
this.thisData.stockOrderLists = this.codeArray;
this.selectProductVisible = true; this.selectProductVisible = true;
} }
} else { } else {
@ -718,26 +720,30 @@ export default {
}, },
closeDialogC2(rData) {//012693548470801311200226172302271020022632100025 closeDialogC2(rData) {
this.selectProductVisible = false; this.selectProductVisible = false;
this.thisData = {}; this.thisData = {};
if (this.$isNotBlank(rData)) { if (this.$isNotBlank(rData)) {
console.log(rData) console.log(rData)
for (let i = 0; i < this.codeArray.length; i++) { // for (let i = 0; i < this.codeArray.length; i++) {
let obj = this.codeArray[i]; // let obj = this.codeArray[i];
if (obj.batchNo == rData[0].batchNo) { // if (obj.batchNo == rData[0].batchNo) {
obj.count = parseInt(obj.count) + parseInt(this.iCount); // obj.count = parseInt(obj.count) + parseInt(this.iCount);
return; // return;
} // }
} // }
this.codeArray = [];
rData.forEach((obj, index) => { rData.forEach((obj, index) => {
if (this.codeArray.length === 0) { // this.codeArray.push(obj);
this.codeArray.push(obj); this.codeArray.unshift(obj);
} else { // if (this.codeArray.length === 0) {
this.codeArray.unshift(obj); // this.codeArray.push(obj);
} // } else {
// this.codeArray.unshift(obj);
// }
}); });
console.log(this.codeArray);
this.$refs.multipleTable.setCurrentRow(this.codeArray[0]); this.$refs.multipleTable.setCurrentRow(this.codeArray[0]);
this.currentRow = this.codeArray[0]; this.currentRow = this.codeArray[0];
this.selectedIndex = 0; this.selectedIndex = 0;

@ -508,20 +508,24 @@ export default {
this.$message.warning('未添加产品'); this.$message.warning('未添加产品');
return; return;
} }
for (let i = 0; i < this.codeArray.length; i++) {
if (this.$isBlank(this.codeArray[i].batchNo)) {
return this.$message.error('批次号不能为空');
}
if (this.$isBlank(this.codeArray[i].productDate)) {
return this.$message.error('生产日期不能为空');
}
if (this.$isBlank(this.codeArray[i].expireDate)) {
return this.$message.error('失效日期不能为空');
}
}
if (status === '2') { if (status === '2') {
this.submitFunction(status); this.submitFunction(status);
} else { } else {
for (let i = 0; i < this.codeArray.length; i++) {
if (this.$isBlank(this.codeArray[i].batchNo)) {
return this.$message.error('批次号不能为空');
}
if (this.$isBlank(this.codeArray[i].productDate)) {
return this.$message.error('生产日期不能为空');
}
if (this.$isBlank(this.codeArray[i].expireDate)) {
return this.$message.error('失效日期不能为空');
}
if (this.$isBlank(this.codeArray[i].reCount) || this.codeArray[i].reCount === '0') {
return this.$message.error('配货数量不能小于0');
}
}
this.$confirm("是否确定提交订单?", "提示", { this.$confirm("是否确定提交订单?", "提示", {
confirmButtonText: "确定", confirmButtonText: "确定",
cancelButtonText: "取消", cancelButtonText: "取消",
@ -532,6 +536,8 @@ export default {
this.loading = false; this.loading = false;
}); });
} }
} }
}); });
}, },

File diff suppressed because it is too large Load Diff

@ -256,7 +256,7 @@
placeholder="请输入批次号" style="width: 80%"></el-input> placeholder="请输入批次号" style="width: 80%"></el-input>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column width="180" label="生产日期1"> <el-table-column width="180" label="生产日期">
<template slot-scope="scope"> <template slot-scope="scope">
<el-date-picker <el-date-picker
@ -270,16 +270,27 @@
</el-date-picker> </el-date-picker>
<!-- <el-input size="small" v-model="scope.row.productDate"--> <!-- <el-input size="small" v-model="scope.row.productDate"-->
<!-- :disabled="scope.row.index !== selectedIndex"--> <!-- :disabled="scope.row.index !== selectedIndex"-->
<!-- placeholder="请输入生产日期" style="width: 80%"></el-input>--> <!-- placeholder="请输入生产日期" style="width: 80%"></el-input>-->
</template> </template>
</el-table-column> </el-table-column>
<el-table-column width="180" label="失效日期"> <el-table-column width="180" label="失效日期">
<template slot-scope="scope"> <template slot-scope="scope">
<el-input size="small" v-model="scope.row.expireDate" <!-- <el-input size="small" v-model="scope.row.expireDate"-->
:disabled="scope.row.index !== selectedIndex" <!-- :disabled="scope.row.index !== selectedIndex"-->
placeholder="请输入失效日期" style="width: 80%"></el-input> <!-- placeholder="请输入失效日期" style="width: 80%"></el-input>-->
<el-date-picker
type="date"
size="small" v-model="scope.row.expireDate"
:disabled="scope.row.index !== selectedIndex"
placeholder="请输入失效日期" style="width: 80%"
value-format="yyMMdd"
format="yyyy-MM-dd"
>
</el-date-picker>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column width="150" label="单据数量"> <el-table-column width="150" label="单据数量">
@ -292,16 +303,16 @@
oninput="value=value.replace(/[^\d]/g,'')"></el-input> oninput="value=value.replace(/[^\d]/g,'')"></el-input>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column width="150" label="实际数量"> <!-- <el-table-column width="150" label="实际数量">-->
<template slot-scope="scope"> <!-- <template slot-scope="scope">-->
<el-input size="small" v-model="scope.row.reCount" <!-- <el-input size="small" v-model="scope.row.reCount"-->
placeholder="请输入数量" style="width: 80%" <!-- placeholder="请输入数量" style="width: 80%"-->
type='number' <!-- type='number'-->
@change="tableCountChange(scope.row)" <!-- @change="tableCountChange(scope.row)"-->
:disabled="scope.row.index !== selectedIndex" <!-- :disabled="scope.row.index !== selectedIndex"-->
oninput="value=value.replace(/[^\d]/g,'')"></el-input> <!-- oninput="value=value.replace(/[^\d]/g,'')"></el-input>-->
</template> <!-- </template>-->
</el-table-column> <!-- </el-table-column>-->
<el-table-column width="150" label="价格"> <el-table-column width="150" label="价格">
<template slot-scope="scope"> <template slot-scope="scope">
<el-input size="small" v-model="scope.row.price" <el-input size="small" v-model="scope.row.price"
@ -519,17 +530,32 @@ export default {
this.$message.warning('未添加产品'); this.$message.warning('未添加产品');
return; return;
} }
for (let i = 0; i < this.codeArray.length; i++) { if (status === '3') {
if (this.$isBlank(this.codeArray[i].batchNo)) { for (let i = 0; i < this.codeArray.length; i++) {
return this.$message.error('批次号不能为空'); if (this.$isBlank(this.codeArray[i].batchNo)) {
} return this.$message.error('批次号不能为空');
if (this.$isBlank(this.codeArray[i].productDate)) { }
return this.$message.error('生产日期不能为空'); if (this.$isBlank(this.codeArray[i].productDate)) {
return this.$message.error('生产日期不能为空');
}
if (this.$isBlank(this.codeArray[i].expireDate)) {
return this.$message.error('失效日期不能为空');
}
if (this.$isBlank(this.codeArray[i].count) || this.codeArray[i].count === '0') {
return this.$message.error('单据数量不能小于0');
}
} }
if (this.$isBlank(this.codeArray[i].expireDate)) { }
return this.$message.error('失效日期不能为空');
if (status === '2') {
for (let i = 0; i < this.codeArray.length; i++) {
if (this.$isBlank(this.codeArray[i].count) || this.codeArray[i].count === '0') {
return this.$message.error('单据数量不能小于0');
}
} }
} }
if (status === '501') { if (status === '501') {
this.submitFunction(status); this.submitFunction(status);
} else { } else {
@ -618,7 +644,6 @@ export default {
}); });
}, },
selectProductFunction(event) { selectProductFunction(event) {
if (event == null) { if (event == null) {
this.$refs.inputRef.focus(); this.$refs.inputRef.focus();
} else event.target.select(); } else event.target.select();
@ -631,6 +656,8 @@ export default {
this.thisData.code = ""; this.thisData.code = "";
this.thisData.orderEditor = this.orderEditor; this.thisData.orderEditor = this.orderEditor;
this.thisData.orderId = ""; this.thisData.orderId = "";
console.log("-----1---" + this.thisData.stockOrderLists)
this.thisData.stockOrderLists = this.codeArray;
if (this.orderEditor) { if (this.orderEditor) {
this.thisData.orderId = this.formData.id this.thisData.orderId = this.formData.id
} }
@ -664,7 +691,8 @@ export default {
let ids = [response.data.getId]; let ids = [response.data.getId];
let tQuery2 = { let tQuery2 = {
ids: ids, ids: ids,
udiEntity: response.data udiEntity: response.data,
stockOrderLists: this.codeArray,
}; };
getStockOrderDetailInstrumentById(tQuery2).then((response) => { getStockOrderDetailInstrumentById(tQuery2).then((response) => {
this.loading = false; this.loading = false;
@ -677,34 +705,6 @@ export default {
this.loading = false; this.loading = false;
}); });
// let tQuery2 = {
// id: response.data.getId
// };
// if (this.orderEditor) {
// tQuery2.orderId = this.formData.id;
// console.log(tQuery2)
// addStockOrderDetailFromCodeById(tQuery2).then((response) => {
// this.loading = false;
// if (response.code === 20000) {
// this.closeDialogC2(response);
// } else {
// this.$message.error(response.message);
// }
// }).catch(() => {
// this.loading = false;
// });
// } else {
// getStockOrderDetailInstrumentById(tQuery2).then((response) => {
// this.loading = false;
// if (response.code === 20000) {
// this.closeDialogC2(response.data);
// } else {
// this.$message.error(response.message);
// }
// }).catch(() => {
// this.loading = false;
// });
// }
} else { } else {
this.thisData = response.data; this.thisData = response.data;
this.thisData.code = this.code; this.thisData.code = this.code;
@ -713,6 +713,7 @@ export default {
if (this.orderEditor) { if (this.orderEditor) {
this.thisData.orderId = this.formData.id this.thisData.orderId = this.formData.id
} }
this.thisData.stockOrderLists = this.codeArray;
this.selectProductVisible = true; this.selectProductVisible = true;
} }
} else { } else {
@ -728,25 +729,27 @@ export default {
}, },
closeDialogC2(rData) {//012693548470801311200226172302271020022632100025 closeDialogC2(rData) {
this.selectProductVisible = false; this.selectProductVisible = false;
this.thisData = {}; this.thisData = {};
if (this.$isNotBlank(rData)) { if (this.$isNotBlank(rData)) {
console.log(rData) console.log(rData)
for (let i = 0; i < this.codeArray.length; i++) { // for (let i = 0; i < this.codeArray.length; i++) {
let obj = this.codeArray[i]; // let obj = this.codeArray[i];
if (obj.batchNo == rData[0].batchNo) { // if (obj.batchNo == rData[0].batchNo) {
obj.count = parseInt(obj.count) + parseInt(this.iCount); // obj.count = parseInt(obj.count) + parseInt(this.iCount);
return; // break;
} // }
} // }
this.codeArray = [];
rData.forEach((obj, index) => { rData.forEach((obj, index) => {
if (this.codeArray.length === 0) { // if (this.codeArray.length === 0) {
this.codeArray.push(obj); // this.codeArray.push(obj);
} else { // } else {
this.codeArray.unshift(obj); // this.codeArray.unshift(obj);
} // }
this.codeArray.unshift(obj);
}); });
this.$refs.multipleTable.setCurrentRow(this.codeArray[0]); this.$refs.multipleTable.setCurrentRow(this.codeArray[0]);
this.currentRow = this.codeArray[0]; this.currentRow = this.codeArray[0];

@ -109,236 +109,238 @@
</template> </template>
<script> <script>
import { import {
getStockOrderDetailInstrumentById, getStockOrderDetailInstrumentById,
stockOrderDetailFilterProduct stockOrderDetailFilterProduct
} from "../../api/warehouse/stockOrder"; } from "../../api/warehouse/stockOrder";
import store from "../../store"; import store from "../../store";
export default { export default {
name: "closeDialog", name: "closeDialog",
props: { props: {
data: { data: {
type: Object, type: Object,
required: true, required: true,
}, },
closeDialog: { closeDialog: {
type: Function, type: Function,
required: true, required: true,
},
}, },
},
data() { data() {
return { return {
listQuery: { listQuery: {
billNo: "", billNo: "",
page: 1, page: 1,
limit: 10, limit: 10,
}, },
combineQuery: { combineQuery: {
thirdId: "", thirdId: "",
relId: "", relId: "",
erpName: "", erpName: "",
keys: [], keys: [],
}, },
dataList: [], dataList: [],
pageTotal: 1, pageTotal: 1,
total: 1, total: 1,
currentRow: null, currentRow: null,
loading: false, loading: false,
multipleUdiSelection: [], multipleUdiSelection: [],
thirdSys: [], thirdSys: [],
thirdSysFk: null, thirdSysFk: null,
busTypes: [], busTypes: [],
actDateRange: [], actDateRange: [],
pickerOptions: { pickerOptions: {
shortcuts: [ shortcuts: [
{ {
text: "最近一周", text: "最近一周",
onClick(picker) { onClick(picker) {
const end = new Date(); const end = new Date();
const start = new Date(); const start = new Date();
start.setTime(start.getTime() - 3600 * 1000 * 24 * 7); start.setTime(start.getTime() - 3600 * 1000 * 24 * 7);
picker.$emit("pick", [start, end]); picker.$emit("pick", [start, end]);
},
}, },
{ },
text: "最近一个月", {
onClick(picker) { text: "最近一个月",
const end = new Date(); onClick(picker) {
const start = new Date(); const end = new Date();
start.setTime(start.getTime() - 3600 * 1000 * 24 * 30); const start = new Date();
picker.$emit("pick", [start, end]); start.setTime(start.getTime() - 3600 * 1000 * 24 * 30);
}, picker.$emit("pick", [start, end]);
}, },
{ },
text: "最近三个月", {
onClick(picker) { text: "最近三个月",
const end = new Date(); onClick(picker) {
const start = new Date(); const end = new Date();
start.setTime(start.getTime() - 3600 * 1000 * 24 * 90); const start = new Date();
picker.$emit("pick", [start, end]); start.setTime(start.getTime() - 3600 * 1000 * 24 * 90);
}, picker.$emit("pick", [start, end]);
}, },
], },
}, ],
orderEditor: false, },
orderId: "", orderEditor: false,
orderId: "",
};
},
methods: {
onReset() {
this.$router.push({
path: "",
});
this.listQuery = {
unionCode: null,
udiCode: null,
ylqxzcrbarmc: "",
cpmctymc: "", thrPiId: null,
nameCode: "",
ggxh: null,
page: 1,
limit: 20,
addType: 1,
}; };
this.getList();
}, },
methods: { tableRowClassName({row}) {
onReset() { if (row.checked) return "warning-row";
this.$router.push({ return "";
path: "", },
}); checkSelectable(row) {
this.listQuery = { return !row.check;
unionCode: null, },
udiCode: null, handleCurrentChange(val) {
ylqxzcrbarmc: "", this.unionQuery.page = val;
cpmctymc: "", thrPiId: null, this.getList();
nameCode: "", },
ggxh: null, handleChange(val) {
page: 1, console.log(val);
limit: 20, this.currentRow = val;
addType: 1, },
}; handleErpPageChange(val) {
this.getList(); this.listQuery.page = val;
}, this.getList();
tableRowClassName({row}) { },
if (row.checked) return "warning-row"; keyup_submit(event) {
return ""; this.listQuery.page = 1;
}, this.getList();
checkSelectable(row) { event.target.select();
return !row.check; },
}, getList() {
handleCurrentChange(val) { this.loading = true;
this.unionQuery.page = val; this.listQuery.customerId = store.getters.customerId;
this.getList(); stockOrderDetailFilterProduct(this.listQuery)
}, .then((response) => {
handleChange(val) { console.log(response)
console.log(val);
this.currentRow = val;
},
handleErpPageChange(val) {
this.listQuery.page = val;
this.getList();
},
keyup_submit(event) {
this.listQuery.page = 1;
this.getList();
event.target.select();
},
getList() {
this.loading = true;
this.listQuery.customerId = store.getters.customerId;
stockOrderDetailFilterProduct(this.listQuery)
.then((response) => {
console.log(response)
this.loading = false;
if (response.code === 20000) {
this.dataList = response.data.list || [];
this.pageTotal = response.data.total || 0;
} else {
this.$message.error(response.message);
this.dataList = [];
this.pageTotal = 0;
}
})
.catch(() => {
this.loading = false;
this.dataList = [];
this.pageTotal = 0;
});
},
intentBack() {
this.closeDialog();
},
combine() {//012693548470801311200226172302271020022632100025
// if (this.$isBlank(this.currentRow.id)) {
// return;
// }
let selection = this.$refs.multipleTable.selection;
if (selection.length < 1) {
this.$message.error('未选择产品');
return;
}
let ids = [];
selection.forEach((obj, index) => {
ids.push(obj.rlId);
});
this.loading = true;
let tQuery = {
ids: ids
};
getStockOrderDetailInstrumentById(tQuery).then((response) => {
this.loading = false; this.loading = false;
if (response.code === 20000) { if (response.code === 20000) {
this.closeDialog(response.data); this.dataList = response.data.list || [];
this.pageTotal = response.data.total || 0;
} else { } else {
this.$message.error(response.message); this.$message.error(response.message);
this.dataList = [];
this.pageTotal = 0;
} }
}).catch(() => { })
.catch(() => {
this.loading = false; this.loading = false;
this.dataList = [];
this.pageTotal = 0;
}); });
// let tQuery = {
// id: this.currentRow.id
// };
// if (this.orderEditor) {
// tQuery.orderId = this.orderId;
// console.log(tQuery)
// addStockOrderDetailFromCodeById(tQuery).then((response) => {
// this.loading = false;
// if (response.code === 20000) {
// this.closeDialog(response);
// } else {
// this.$message.error(response.message);
// }
// }).catch(() => {
// this.loading = false;
// });
// } else {
// getStockOrderDetailInstrumentById(tQuery).then((response) => {
// this.loading = false;
// if (response.code === 20000) {
// this.closeDialog(response.data);
// } else {
// this.$message.error(response.message);
// }
// }).catch(() => {
// this.loading = false;
// });
// }
},
handleSelectionUdiChange(val) {
console.log("----" + val);
this.multipleUdiSelection = val;
},
}, },
created() { intentBack() {
if (this.$isNotBlank(this.data)) { this.closeDialog();
this.listQuery.nameCode = this.data.udi; },
this.orderEditor = this.data.orderEditor; combine() {//012693548470801311200226172302271020022632100025
this.orderId = this.data.orderId; // if (this.$isBlank(this.currentRow.id)) {
this.getList(); // return;
// }
let selection = this.$refs.multipleTable.selection;
if (selection.length < 1) {
this.$message.error('未选择产品');
return;
} }
let ids = [];
selection.forEach((obj, index) => {
ids.push(obj.rlId);
});
this.loading = true;
let tQuery = {
ids: ids,
stockOrderLists: this.data.stockOrderLists,
};
getStockOrderDetailInstrumentById(tQuery).then((response) => {
this.loading = false;
if (response.code === 20000) {
this.closeDialog(response.data);
} else {
this.$message.error(response.message);
}
}).catch(() => {
this.loading = false;
});
// let tQuery = {
// id: this.currentRow.id
// };
// if (this.orderEditor) {
// tQuery.orderId = this.orderId;
// console.log(tQuery)
// addStockOrderDetailFromCodeById(tQuery).then((response) => {
// this.loading = false;
// if (response.code === 20000) {
// this.closeDialog(response);
// } else {
// this.$message.error(response.message);
// }
// }).catch(() => {
// this.loading = false;
// });
// } else {
// getStockOrderDetailInstrumentById(tQuery).then((response) => {
// this.loading = false;
// if (response.code === 20000) {
// this.closeDialog(response.data);
// } else {
// this.$message.error(response.message);
// }
// }).catch(() => {
// this.loading = false;
// });
// }
},
handleSelectionUdiChange(val) {
console.log("----" + val);
this.multipleUdiSelection = val;
}, },
}; },
created() {
if (this.$isNotBlank(this.data)) {
console.log(this.data.stockOrderLists);
this.listQuery.nameCode = this.data.udi;
this.orderEditor = this.data.orderEditor;
this.orderId = this.data.orderId;
this.getList();
}
},
};
</script> </script>
<style scoped> <style scoped>
.query-form-item { .query-form-item {
display: block !important; display: block !important;
margin-right: 10px; margin-right: 10px;
margin-bottom: 5px; margin-bottom: 5px;
} }
div /deep/ .el-table .warning-row { div /deep/ .el-table .warning-row {
background: #bebebe; background: #bebebe;
} }
div /deep/ .el-table .success-row { div /deep/ .el-table .success-row {
background: #ffffff; background: #ffffff;
} }
</style> </style>

@ -505,12 +505,16 @@ export default {
} }
}, },
printOrder(row) { printOrder(row) {
let tQuery = {queryId: row.id,} let tQuery = {
queryId: row.id,
}
this.loading = true; this.loading = true;
inspectionStockOrderPDFFromTemplateFile(tQuery).then((response) => { inspectionStockOrderPDFFromTemplateFile(tQuery).then((response) => {
if (response.code === 20000) { if (response.code === 20000) {
tQuery = { tQuery = {
id: row.id, id: row.id,
orderName: "送货单",
} }
stockOrderPDFFromTemplateFile(tQuery).then((response) => { stockOrderPDFFromTemplateFile(tQuery).then((response) => {
//pdfurl //pdfurl

Loading…
Cancel
Save