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

633 lines
21 KiB
Vue

<template>
<div>
<el-row :gutter="0" v-if="isLinkDisabled" style="margin-top: 15px">
7 months ago
<el-col :span="2" align="left">
<img v-if="logo" :src="logo" class="sidebar-logo"/>
</el-col>
7 months ago
<div>
7 months ago
<el-form :model="formData" class="order-el-form" ref="formData" label-width="120px" >
7 months ago
7 months ago
<el-col :span="18" style="margin-left: 0px" >
7 months ago
<span style="font-size: 16px;color: #409EFF">当前工位:&nbsp&nbsp&nbsp&nbsp<span style="font-size: 16px;color: #000000">{{this.formData.workplaceName}}</span>
7 months ago
&nbsp&nbsp&nbsp&nbsp
<!-- <span :style="{ color: formData.workplaceStatus === 0 ? 'green' : 'red' }"> ({{ formData.workplaceStatus === 0 ? '服务中' : '服务暂停' }} ) </span>-->
7 months ago
<!-- <el-button type="primary" @click="toggleWorkplaceStatus" style="margin-left: 10px;" >切换状态</el-button>-->
7 months ago
</span>
7 months ago
<span style="font-size: 16px;color: #409EFF;margin-left: 20px">当前业务类型:&nbsp&nbsp&nbsp&nbsp<span style="font-size: 16px;color: #000000">{{this.formData.busName}}</span>
7 months ago
&nbsp&nbsp&nbsp&nbsp <el-button type="primary" @click="toggleBusType" style="margin-left: 10px;" >切换业务</el-button>
7 months ago
<el-button type="danger" @click="closeAllTabs" style="margin-left: 10px;" v-if="this.showContextMenu"></el-button>
7 months ago
</span>
7 months ago
</el-col>
7 months ago
</el-form>
</div>
7 months ago
<el-col :span="4" align="right" style="margin-top: 10px">
<div class="inv-hos-title">
7 months ago
<span
style="margin: 10px;color: #2d8cf0;font-size: 14px;"
>部门&nbsp:&nbsp{{ this.userInfo.deptName }}</span>
<span
7 months ago
style="font-weight: 500;color:rgb(51 48 48); font-size: 14px; margin-right: 20px"
>&nbsp&nbsp&nbsp&nbsp(用户&nbsp:&nbsp{{
this.userInfo.userName
}})</span>
</div>
</el-col>
7 months ago
</el-row>
<el-row class="tac">
<el-col :span="2">
<!-- <h5>默认颜色</h5>-->
<el-menu
:default-active="menuActive"
class="el-menu-vertical-demo"
7 months ago
style="width: 100%"
unique-opened="true"
@open="handleOpen">
7 months ago
7 months ago
<el-submenu index="11">
<template slot="title">
<i class="el-icon-s-order"></i>
<span>单据管理</span>
</template>
<el-menu-item :index=0 @click="clickMenuItem(0)">
<!-- <i class="el-icon-edit-outline"></i>-->
<span slot="title">处理单据</span>
</el-menu-item>
<el-menu-item :index=4 @click="clickMenuItem(4)">
<!-- <i class="el-icon-s-order"></i>-->
<span slot="title">待处理单</span>
</el-menu-item>
<el-menu-item :index=5 @click="clickMenuItem(5)">
<!-- <i class="el-icon-s-claim"></i>-->
<span slot="title">已完成单</span>
</el-menu-item>
<el-menu-item :index=6 @click="clickMenuItem(6)">
7 months ago
<!-- <i class="el-icon-upload"></i>-->
<span slot="title">单据上传</span>
</el-menu-item>
7 months ago
</el-submenu>
<el-submenu index="33" v-if="autoTag == 1">
7 months ago
<template slot="title">
<i class="el-icon-s-platform"></i>
<span>工位管理</span>
</template>
7 months ago
<el-menu-item :index=1 @click="clickMenuItem(1)">
7 months ago
<!-- <i class="el-icon-s-unfold"></i>-->
7 months ago
<span slot="title">工位上货</span>
</el-menu-item>
<el-menu-item :index=2 @click="clickMenuItem(2)">
7 months ago
<!-- <i class="el-icon-s-fold"></i>-->
7 months ago
<span slot="title">工位退货</span>
</el-menu-item>
<el-menu-item :index=3 @click="clickMenuItem(3)">
7 months ago
<!-- <i class="el-icon-s-platform"></i>-->
7 months ago
<span slot="title">工位库存</span>
7 months ago
</el-menu-item>
7 months ago
<el-menu-item :index=7 @click="clickMenuItem(7)">
<!-- <i class="el-icon-s-help"></i>-->
<span slot="title">拆零管理</span>
</el-menu-item>
<el-menu-item :index=8 @click="clickMenuItem(8)">
<!-- <i class="el-icon-warning"></i>-->
<span slot="title">存量预警</span>
</el-menu-item>
7 months ago
</el-submenu>
7 months ago
<!--<el-submenu index="22" v-if="autoTag == 1">-->
<!-- <template slot="title">-->
<!-- <i class="el-icon-s-help"></i>-->
<!-- <span>库存管理</span>-->
<!-- </template>-->
<!--</el-submenu>-->
7 months ago
</el-menu>
</el-col>
<el-col :span="22">
<el-tabs v-model="editableTabsValue" type="card" closable @tab-remove="removeTab"
7 months ago
@tab-click="upodateMenuActive" @contextmenu.native.prevent="handleContextMenu">
<el-tab-pane
v-for="(item, index) in editableTabs"
:key="item.name"
:label="item.title"
:name="item.name"
7 months ago
@contextmenu.stop.prevent="handleTabContextMenu($event, item)"
7 months ago
style="background-color: white"
>
7 months ago
<!-- <ul v-if="showContextMenu" class="context-menu" :style="contextMenuPosition">-->
<!-- <li @click="closeAllTabs"></li>-->
<!-- </ul>-->
7 months ago
<div >
7 months ago
<component v-if="showChild" :is="item.component" v-bind="item.componentProps" :reset-key="resetKeys[item.name]" @parent-method="parentMethod"
style="margin-top: -14px"/>
7 months ago
</div>
</el-tab-pane>
</el-tabs>
</el-col>
</el-row>
7 months ago
<el-dialog
title="选择业务类型"
:visible.sync="selectBusTypeDisabled"
:close-on-click-modal="false"
:close-on-press-escape="false"
7 months ago
:show-close="selectBusTypeClosrrButDisabled"
7 months ago
v-if="selectBusTypeDisabled"
width="65%"
append-to-body
>
7 months ago
<el-row :gutter="24">
<el-col :span="24" style="display: flex; justify-content: flex-end;">
<el-button @click="toggleContent" type="primary" style="margin-right: 20px;">
<span v-if="!isContentVisible"></span>
<span v-if="isContentVisible"></span>
<i :class="{'el-icon-caret-right': !isContentVisible, 'el-icon-caret-bottom': isContentVisible}"> </i>
<!-- 这里原本想用大括号图标但Font Awesome默认没有所以用了上下箭头代替 -->
</el-button>
</el-col>
</el-row>
7 months ago
<el-row>
<!-- <el-button v-for="(item, index) in busTypeList" :key="index" type="primary" plain @click="selectBusType(item.code)">{{ item.name }}</el-button>-->
<el-col v-for="(info, index) in busTypeList" :key="index" :xs="12" :sm="8" :md="8" :lg="6">
<el-card :body-style="{margin:'20px'}"
style="margin:20px 20px 20px 20px;height: 200px;background-color: #e1f3fb;border-radius: 12px; position: relative;"
>
<div
style="display: flex; justify-content: space-between; align-items: center; height: 46px; /* 约为 200px 的 1/3 */"
7 months ago
@click="selectBusType(info)">
7 months ago
<p style="font-size: 20px;background-color: #e1f3fb;font-weight: bold;">{{ info.busName }}</p>
<!-- 假设你的信息对象中包含一个title属性 -->
<!-- <div style="width: 60px; height: 60px; display: flex; justify-content: center; align-items: center;">-->
<!-- &lt;!&ndash; 二维码占位这里用灰色方块代替 &ndash;&gt;-->
<!--&lt;!&ndash; <span>QR</span>&ndash;&gt;-->
<!-- <div ref="qrcode" :id="'qrcode-'+index" style="width: 60px;height: 60px;"></div>-->
<!-- </div>-->
</div>
<div style="flex: 1; display: flex; flex-direction: column; justify-content: flex-end; padding-top: 10px;"
>
<!-- 假设这里有一些信息内容 -->
7 months ago
<p style="font-size: 14px;background-color: #e1f3fb" @click="selectBusType(info)">
{{ info.remark }}</p>
7 months ago
<el-button type="primary" style="position: absolute; bottom: 20px; right: 20px;" icon="el-icon-thumb"
7 months ago
@click="selectBusType(info)">开始作业
7 months ago
</el-button>
</div>
</el-card>
</el-col>
</el-row>
</el-dialog>
7 months ago
</div>
7 months ago
</template>
<script>
import logoImg from '@/assets/logo/logo_dm.png'
7 months ago
import DealOrder from '@/views/collect/DealOrder.vue'
import CollectOrderAllot from '@/views/collect/CollectOrderAllot.vue'
import CollectOrderEnd from '@/views/collect/CollectOrderEnd.vue'
import IoCreateOrderReturn from '@/views/collect/IoCreateOrder.vue'
import IoCreateOrderOut from '@/views/collect/IoCreateOrder.vue'
7 months ago
import ioSplitFifoCode from '@/views/collect/ioSplitFifoCode.vue'
import CollectOrderUpload from '@/views/collect/CollectOrderUpload.vue'
7 months ago
import IoDestroyOrder from '@/views/collect/IoDestroyOrder.vue'
7 months ago
import IoSplitFifoRemind from '@/views/collect/IoSplitFifoRemind.vue'
import {listPage,switchWorkplaceStatus} from "@/api/basic/workPlace/sysWorkplaceManage";
7 months ago
import {getWorkBindBusTypes, removeBusTypeById} from '@/api/basic/workPlace/sysWorkplaceDocuments'
export default {
components: {
7 months ago
DealOrder,
IoCreateOrderReturn,
IoCreateOrderOut,
ioSplitFifoCode,
CollectOrderAllot,
CollectOrderEnd,
7 months ago
CollectOrderUpload,
IoDestroyOrder
},
name: 'CollectOrderTabs',
data() {
return {
7 months ago
isContentVisible: false, // 控制内容是否显示
7 months ago
showContextMenu: false, // 控制上下文菜单的显示
contextMenuPosition: { x: 0, y: 0 }, // 上下文菜单的位置
7 months ago
selectBusTypeDisabled: false,
7 months ago
selectBusTypeClosrrButDisabled: false,
7 months ago
selectWorkplaceStatusDisabled: false,
7 months ago
busQuery: {
busKey: '',
7 months ago
isPopular: 1,
7 months ago
workplaceCode: null,
page: 1,
limit: 100
},
7 months ago
formData: {
busName: null,
7 months ago
workplaceName: null,
workplaceStatus: null
7 months ago
},
curWorkPlaces: [],
busTypeList: [],
logo: logoImg,
isLinkDisabled: false,
7 months ago
showChild: true,
userInfo: {
inv: this.$store.getters.locInvName,
deptName: this.$store.getters.locDeptName,
userName: this.$store.getters.user.employeeName,
companyName: this.$store.getters.companyName
},
tabPosition: 'left',
7 months ago
editableTabsValue: 'DealOrder',
componentTables: [
{
number: 0,
title: '处理单据',
7 months ago
name: 'DealOrder',
component: DealOrder,
// 假设你需要传递的参数
componentProps: {
7 months ago
// title: '这是单据的标题',
}
},
{
number: 1,
title: '工位上货',
7 months ago
name: 'IoCreateOrderOut',
component: IoCreateOrderOut,
// 假设你需要传递的参数
componentProps: {
fromSplitType: 'out',
}
},
{
number: 2,
title: '工位退货',
7 months ago
name: 'IoCreateOrderReturn',
component: IoCreateOrderReturn,
// 假设你需要传递的参数
componentProps: {
fromSplitType: 'return'
}
},
{
number: 3,
7 months ago
title: '工位库存',
7 months ago
name: 'ioSplitFifoCode',
component: ioSplitFifoCode,
// 假设你需要传递的参数
componentProps: {}
},
{
number: 4,
title: '待处理单',
7 months ago
name: 'CollectOrderAllot',
component: CollectOrderAllot,
// 假设你需要传递的参数
componentProps: {}
},
{
number: 5,
title: '已完成单',
7 months ago
name: 'CollectOrderEnd',
component: CollectOrderEnd,
// 假设你需要传递的参数
componentProps: {}
},
{
number: 6,
title: '单据上传',
name: 'CollectOrderUpload',
component: CollectOrderUpload,
// 假设你需要传递的参数
componentProps: {}
7 months ago
},
{
number: 7,
7 months ago
title: '拆零管理',
7 months ago
name: 'IoDestroyOrder',
component: IoDestroyOrder,
// 假设你需要传递的参数
componentProps: {}
7 months ago
},
{
number: 8,
title: '存量预警',
name: 'IoSplitFifoRemind',
component: IoSplitFifoRemind,
// 假设你需要传递的参数
componentProps: {}
}],
editableTabs: [{
number: 0,
title: '处理单据',
7 months ago
name: 'DealOrder',
component: DealOrder,
// 假设你需要传递的参数
componentProps: {
7 months ago
// title: '这是单据的标题'
}
}
],
tabIndex: 0,
7 months ago
menuActive: 0,
autoTag: 0,
resetKeys: {}
}
},
methods: {
7 months ago
toggleContent() {
// 切换isContentVisible的值
this.isContentVisible = !this.isContentVisible;
//判断是否展开 展开 就查全部/折叠就是 常用的
// todo 2024/09/09
if (this.isContentVisible){
this.busQuery.isPopular = 0
}else {
this.busQuery.isPopular = 1
}
this.getWorkBindBusTypes(this.formData.workplaceId)
},
7 months ago
toggleWorkplaceStatus() {
if (this.formData.workplaceStatus == 0){
this.formData.workplaceStatus = 1
}else {
this.formData.workplaceStatus = 0
}
switchWorkplaceStatus(this.formData).then(resp => {
if (resp.code == 20000){
this.$message.success("切换成功!")
}else {
this.$message.error(resp.message)
if (this.formData.workplaceStatus == 0){
this.formData.workplaceStatus = 1
}else {
this.formData.workplaceStatus = 0
}
}
}).catch(() => {
})
},
toggleBusType() {
7 months ago
//隐藏下拉框内容
// this.$refs.selectHeadEmpId.blur();
7 months ago
//切换业务时 可以有关闭按钮展示
this.selectBusTypeClosrrButDisabled = true
7 months ago
this.selectBusTypeDisabled = true
},
7 months ago
selectBusType(info) {
let val = info.documentTypeCode
7 months ago
this.formData.busType = val
let newQuery = {...this.$route.query};
7 months ago
delete newQuery.billNo;
newQuery.busType = val
this.$router.push({query: newQuery, path: this.$route.path});
7 months ago
this.formData.busName = info.busName;
this.autoTag = info.autoTag;
7 months ago
this.editableTabs = []
this.clickMenuItem(0)
this.showChild = false;
this.$nextTick(() => {
this.showChild = true;
});
this.selectBusTypeDisabled = false
7 months ago
this.selectBusTypeClosrrButDisabled = false
7 months ago
},
7 months ago
parentMethod(data) {
const foundTab = this.findAllTabByName(data)
this.clickMenuItem(foundTab.number)
this.showChild = false;
this.$nextTick(() => {
this.showChild = true;
});
},
upodateMenuActive(tab, event) {
const foundTab = this.findTabByName(tab.name)
if (foundTab) {
// 如果找到了,执行一些操作
this.menuActive = foundTab.number
7 months ago
this.$set(this.resetKeys, foundTab.name, Date.now());
}
},
clickMenuItem(val) {
//分两种 一种已存在 一种未存在
let item = this.componentTables[(val)]
const foundTab = this.findTabByName(item.name)
if (foundTab) {
// 如果找到了,执行一些操作
this.editableTabsValue = foundTab.name
7 months ago
this.$set(this.resetKeys, foundTab.name, Date.now());
7 months ago
this.menuActive = foundTab.number
} else {
// 如果没有找到,执行其他操作
this.addTab(item)
}
},
findTabByName(name) {
// 使用find方法找到ID等于tabId的对象
const tab = this.editableTabs.find(tab => tab.name === name)
// 如果找到了返回该对象否则返回undefined
return tab
},
7 months ago
findAllTabByName(name) {
// 使用find方法找到ID等于tabId的对象
const tab = this.componentTables.find(tab => tab.name === name)
// 如果找到了返回该对象否则返回undefined
return tab
},
addTab(item) {
++this.tabIndex
this.editableTabs.push(item)
this.editableTabsValue = item.name
7 months ago
this.menuActive = item.number
},
removeTab(targetName) {
let tabs = this.editableTabs
let activeName = this.editableTabsValue
if (activeName === targetName) {
tabs.forEach((tab, index) => {
if (tab.name === targetName) {
let nextTab = tabs[index + 1] || tabs[index - 1]
if (nextTab) {
activeName = nextTab.name
this.menuActive = nextTab.number
}
}
})
}
this.editableTabsValue = activeName
this.editableTabs = tabs.filter(tab => tab.name !== targetName)
7 months ago
},
//获取当前货位
findCurWorkPlaces(val) {
let query = {
key: val,
status: 1,
// invCode: this.formData.invCode,
page: 1,
limit: 100,
}
listPage(query).then((res) => {
this.curWorkPlaces = res.data.list || [];
7 months ago
if (this.$route.query.workplaceId != null){
let item = this.curWorkPlaces.find(item => item.workplaceId == this.$route.query.workplaceId);
this.formData.workplaceName = item.workplaceName
7 months ago
this.formData.workplaceStatus = item.workplaceStatus
7 months ago
}
7 months ago
})
},
getWorkBindBusTypes(workplaceId) {
this.busQuery.workplaceCode = workplaceId
getWorkBindBusTypes(this.busQuery).then(res => {
if (res.code == 20000) {
this.busTypeList = res.data.list
this.busTypeTotal = res.data.total
if (this.$route.query.busType != null) {
7 months ago
this.formData.busType = this.$route.query.busType
let busType = this.busTypeList.find(item => item.documentTypeCode == this.formData.busType)
this.formData.busName = busType.busName;
this.autoTag = busType.autoTag;
7 months ago
}else if (this.busTypeList.length == 1) {
this.formData.busType = this.busTypeList[0].documentTypeCode
this.autoTag = this.busTypeList[0].autoTag;
this.$router.push({query: {...this.$route.query, busType: this.formData.busType}, path: this.$route.path})
7 months ago
this.selectBusTypeDisabled = false
7 months ago
this.formData.busName = this.busTypeList.find(item => item.documentTypeCode == this.formData.busType).busName;
7 months ago
} else {
this.selectBusTypeDisabled = true
this.formData.busType = null
}
}
return
})
},
7 months ago
handleContextMenu() {
this.showContextMenu = true;
},
handleTabContextMenu(event, tab) {
7 months ago
this.showContextMenu = true;
7 months ago
// this.contextMenuTab = tab;
// this.contextMenuPosition = { x: event.clientX, y: event.clientY };
7 months ago
},
7 months ago
closeContextMenu() {
this.showContextMenu = false;
7 months ago
// this.contextMenuStyle.display = 'none'; // 隐藏上下文菜单
7 months ago
},
7 months ago
closeCurrentTab(index) {
7 months ago
// 关闭当前标签页的逻辑
7 months ago
this.editableTabs.splice(index, 1); // 假设这是关闭标签页的方式
this.editableTabsValue = this.editableTabs.length > 0 ? this.editableTabs[0].name : '';
this.closeContextMenu();
7 months ago
},
7 months ago
closeOtherTabs() {
7 months ago
// 关闭其他标签页的逻辑
7 months ago
// ...
this.closeContextMenu();
7 months ago
},
7 months ago
closeAllTabs() {
7 months ago
// 关闭所有标签页的逻辑
this.editableTabs = [];
this.editableTabsValue = '';
7 months ago
this.closeContextMenu();
},
7 months ago
},
computed: {
7 months ago
contextMenuPosition() {
7 months ago
return {
7 months ago
position: 'fixed', // 使用 fixed 定位确保它浮动在顶层
7 months ago
left: `${this.contextMenuPosition.x}px`,
top: `${this.contextMenuPosition.y}px`,
7 months ago
zIndex: 1000, // 确保它在其他内容之上
// 其他样式...
7 months ago
};
},
},
created() {
7 months ago
this.findCurWorkPlaces();
if (this.$route.query.workplaceId != null) {
this.isLinkDisabled = true
7 months ago
this.formData.workPlaceCode = Number(this.$route.query.workplaceId);
7 months ago
this.formData.workplaceId = Number(this.$route.query.workplaceId);
7 months ago
this.getWorkBindBusTypes(this.formData.workPlaceCode);
}
}
}
</script>
7 months ago
<style lang="css" scoped>
.sidebar-logo {
width: 80px;
height: 60px;
vertical-align: middle;
margin-left: 25px;
}
7 months ago
.context-menu {
7 months ago
zIndex: 100000;
7 months ago
position: fixed ;
list-style-type: none;
padding: 0;
margin: 0;
background-color: #f9f9f9;
border: 1px solid #d4d4d4;
border-radius: 4px;
/* 其他样式... */
}
.context-menu li {
padding: 8px 16px;
cursor: pointer;
7 months ago
/* 其他样式... */
}
7 months ago
.context-menu li:hover {
background-color: #e1e1e1;
}
7 months ago
.rounded-box {
border-radius: 10px;
background-color: #f8f9fa; /* 浅灰色背景,可选 */
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); /* 可选,添加阴影以增加立体感 */
/*display: flex;*/
/*flex-direction: column;*/
/*align-items: center;*/
}
</style>