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

1201 lines
39 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>
<el-form :model="formData" class="order-el-form" ref="formData" label-width="120px">
7 months ago
1 month ago
<el-col :span="12" style="margin-left: 0px">
<span style="font-size: 14px;color: #909399">当前工位:&nbsp&nbsp&nbsp&nbsp<span
1 month ago
style="font-size: 16px;color: #000000"
>{{ this.formData.workplaceName }}</span>
&nbsp&nbsp&nbsp&nbsp<el-button type="primary" icon="el-icon-sort" @click="toggleWorkplace"
v-if="workPlaceClass == 2"
style="margin-left: 10px;"
>切换工位</el-button>
7 months ago
</span>
<span style="font-size: 14px;color: #909399;margin-left: 20px" v-if="workPlaceClass == 1">:&nbsp&nbsp&nbsp&nbsp<span
1 month ago
style="font-size: 16px;color: #000000"
>{{ this.formData.busName }}</span>
&nbsp&nbsp&nbsp&nbsp <el-button type="primary" icon="el-icon-sort" @click="toggleBusType"
1 month ago
style="margin-left: 10px;"
>切换业务</el-button>
7 months ago
</span>
7 months ago
</el-col>
7 months ago
</el-form>
</div>
7 months ago
1 month ago
<el-col :span="10" 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">
<el-menu
:default-active="menuActive"
class="el-menu-vertical-demo"
7 months ago
style="width: 100%"
unique-opened="true"
1 month ago
@open="handleOpen"
>
<div v-if=" this.productType != 1">
<el-menu-item :index=0 @click="clickMenuItem(0)" v-if="workPlaceClass == 1">
1 month ago
7 months ago
<span slot="title">处理单据</span>
</el-menu-item>
<!--<el-menu-item :index=9 @click="clickMenuItem(9)" v-if="workPlaceClass == 1">-->
1 month ago
<!-- <span slot="title">取药确认</span>-->
<!--</el-menu-item>-->
7 months ago
1 month ago
<el-menu-item :index=10 @click="clickMenuItem(10)" v-if="workPlaceClass == 1">
1 month ago
1 month ago
<span slot="title">单据审核</span>
</el-menu-item>
<!--<el-menu-item :index=4 @click="clickMenuItem(4)" v-if="workPlaceClass == 1">-->
1 month ago
<!-- <span slot="title">待处理单</span>-->
<!--</el-menu-item>-->
<!--<el-menu-item :index=11 @click="clickMenuItem(11)" v-if="workPlaceClass == 1">-->
1 month ago
<!-- <span slot="title">单据校验</span>-->
<!--</el-menu-item>-->
6 months ago
<el-menu-item :index=5 @click="clickMenuItem(5)" v-if="workPlaceClass == 1">
1 month ago
7 months ago
<span slot="title">已完成单</span>
</el-menu-item>
6 months ago
<el-menu-item :index=6 @click="clickMenuItem(6)" v-if="workPlaceClass == 1">
1 month ago
<span slot="title">单据上传</span>
</el-menu-item>
7 months ago
<el-menu-item :index=1 @click="clickMenuItem(1)" v-if="workPlaceClass == 2 && jobMode == 0">
1 month ago
<span slot="title">工位上货</span>
</el-menu-item>
<el-menu-item :index=15 @click="clickMenuItem(15)" v-if="workPlaceClass == 2 && jobMode == 1">
<span slot="title">拆零上货</span>
</el-menu-item>
<el-menu-item :index=16 @click="clickMenuItem(16)" v-if="workPlaceClass == 2 && jobMode == 1">
<span slot="title">整取上货</span>
</el-menu-item>
<!--<el-menu-item :index=13 @click="clickMenuItem(13)" v-if="workPlaceClass == 2">-->
1 month ago
<!-- <span slot="title">工位剔除</span>-->
<!--</el-menu-item>-->
1 month ago
<el-menu-item :index=8 @click="clickMenuItem(8)" v-if="workPlaceClass == 2">
1 month ago
<span slot="title">上货推荐</span>
</el-menu-item>
1 month ago
1 month ago
<el-menu-item :index=3 @click="clickMenuItem(3)" v-if="workPlaceClass == 2 || workPlaceClass == 1">
1 month ago
<span slot="title">工位库存</span>
</el-menu-item>
<el-menu-item :index=17 @click="clickMenuItem(17)" v-if="workPlaceClass == 2">
<span slot="title">库存预览</span>
</el-menu-item>
1 month ago
<el-menu-item :index=7 @click="clickMenuItem(7)" v-if="workPlaceClass == 2">
1 month ago
<span slot="title">拆零管理</span>
</el-menu-item>
1 month ago
<el-menu-item :index=2 @click="clickMenuItem(2)" v-if="workPlaceClass == 2">
1 month ago
<span slot="title">工位退货</span>
</el-menu-item>
1 month ago
<el-menu-item :index=12 @click="clickMenuItem(12)" v-if="workPlaceClass == 2">
1 month ago
<span slot="title">上货记录</span>
</el-menu-item>
1 month ago
<!-- <el-menu-item :index=14 @click="clickMenuItem(14)" v-if="workPlaceClass == 1">-->
1 month ago
1 month ago
<!-- <span slot="title">处理预验收</span>-->
<!-- </el-menu-item>-->
1 month ago
1 month ago
</div>
1 month ago
1 month ago
<div v-if=" this.productType == 1">
1 month ago
<el-menu-item :index=10000 @click="clickMenuItem(10000)" v-if="workPlaceClass == 1">
1 month ago
1 month ago
<span slot="title">处理单据</span>
1 month ago
</el-menu-item>
1 month ago
<el-menu-item :index=1000 @click="clickMenuItem(1000)" v-if="workPlaceClass == 1">
1 month ago
1 month ago
<span slot="title">单据审核</span>
1 month ago
</el-menu-item>
<!--<el-menu-item :index=400 @click="clickMenuItem(400)" v-if="workPlaceClass == 1">-->
1 month ago
<!-- <span slot="title">待处理单</span>-->
<!--</el-menu-item>-->
1 month ago
<el-menu-item :index=500 @click="clickMenuItem(500)" v-if="workPlaceClass == 1">
1 month ago
1 month ago
<span slot="title">已完成单</span>
1 month ago
</el-menu-item>
1 month ago
<el-menu-item :index=600 @click="clickMenuItem(600)" v-if="workPlaceClass == 1">
1 month ago
1 month ago
<span slot="title">单据上传</span>
1 month ago
</el-menu-item>
1 month ago
<el-menu-item :index=100 @click="clickMenuItem(100)" v-if="workPlaceClass == 2">
1 month ago
1 month ago
<span slot="title">工位上货</span>
</el-menu-item>
<!--<el-menu-item :index=1300 @click="clickMenuItem(1300)" v-if="workPlaceClass == 2">-->
1 month ago
<!-- <span slot="title">工位剔除</span>-->
<!--</el-menu-item>-->
1 month ago
<el-menu-item :index=800 @click="clickMenuItem(800)" v-if="workPlaceClass == 2">
1 month ago
1 month ago
<span slot="title">上货推荐</span>
</el-menu-item>
7 months ago
1 month ago
<el-menu-item :index=300 @click="clickMenuItem(300)" v-if="workPlaceClass == 2 || workPlaceClass == 1">
1 month ago
1 month ago
<span slot="title">工位库存</span>
</el-menu-item>
1 month ago
<el-menu-item :index=700 @click="clickMenuItem(700)" v-if="workPlaceClass == 2">
1 month ago
1 month ago
<span slot="title">拆零管理</span>
</el-menu-item>
1 month ago
<el-menu-item :index=200 @click="clickMenuItem(200)" v-if="workPlaceClass == 2">
1 month ago
1 month ago
<span slot="title">工位退货</span>
</el-menu-item>
1 month ago
<el-menu-item :index=1200 @click="clickMenuItem(1200)" v-if="workPlaceClass == 2">
1 month ago
1 month ago
<span slot="title">上货记录</span>
</el-menu-item>
1 month ago
<el-menu-item :index=1400 @click="clickMenuItem(1400)" v-if="workPlaceClass == 1">
1 month ago
1 month ago
<span slot="title">处理预验收</span>
</el-menu-item>
</div>
</el-menu>
</el-col>
<el-col :span="22">
<el-tabs v-model="editableTabsValue" type="card" closable @tab-remove="removeTab"
1 month 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"
>
<div>
<component v-if="showChild" :is="item.component" v-bind="item.componentProps"
:reset-key="resetKeys[item.name]" @parent-method="parentMethod"
1 month ago
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;">
7 months ago
<el-button @click="toggleContent" type="primary" style="margin-right: 20px;">
<span v-if="!isContentVisible"></span>
<span v-if="isContentVisible"></span>
7 months ago
<i :class="{'el-icon-caret-right': !isContentVisible, 'el-icon-caret-bottom': isContentVisible}"> </i>
</el-button>
</el-col>
7 months ago
</el-row>
7 months ago
<el-row>
<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 */"
1 month ago
@click="selectBusType(info)"
>
7 months ago
<p style="font-size: 20px;background-color: #e1f3fb;font-weight: bold;">{{ info.busName }}</p>
</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"
1 month ago
@click="selectBusType(info)"
>开始作业
7 months ago
</el-button>
</div>
</el-card>
</el-col>
</el-row>
</el-dialog>
7 months ago
<el-dialog
title="选择作业工位"
:visible.sync="selectWorkplaceeDisabled"
:close-on-click-modal="false"
:close-on-press-escape="false"
:show-close="selectBusTypeClosrrButDisabled"
v-if="selectWorkplaceeDisabled"
width="65%"
append-to-body
>
<el-row>
<el-col v-for="(info, index) in curWorkPlaces" :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 */"
1 month ago
@click="selectWorkplace(info)"
>
<p style="font-size: 20px;background-color: #e1f3fb;font-weight: bold;">{{ info.workplaceName }}</p>
</div>
<div style="flex: 1; display: flex; flex-direction: column; justify-content: flex-end; padding-top: 10px;"
>
<!-- 假设这里有一些信息内容 -->
<p style="font-size: 14px;background-color: #e1f3fb" @click="selectWorkplace(info)">
{{ info.remark }}</p>
<el-button type="primary" style="position: absolute; bottom: 20px; right: 20px;" icon="el-icon-thumb"
1 month ago
@click="selectWorkplace(info)"
>开始作业
</el-button>
</div>
</el-card>
</el-col>
</el-row>
</el-dialog>
</div>
7 months ago
</template>
<script>
import logoImg from '@/assets/logo/logo_dm.png'
7 months ago
import DealOrder from '@/views/collect/DealOrder.vue'
1 month ago
import DealOrderPre from '@/views/collect/DealOrderPre.vue'
import ConfirmDrugDealOrder from '@/views/collect/ConfirmDrugDealOrder.vue'
7 months ago
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'
import IoCreateOrderOutRecord from '@/views/collect/IoCreateOrderOutRecord.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 IocCollectOrderCheckCode from '@/views/collect/IocCollectOrderCheckCode.vue'
1 month ago
import IocCollectOrderVerify from '@/views/collect/IocCollectOrderVerify.vue'
import IoSplitFifoRemove from '@/views/collect/IoSplitFifoRemove.vue'
import IoSplitCreateOrder from '@/views/collect/IoCreateOrder.vue'
import IoFullCreateOrder from '@/views/collect/IoCreateOrder.vue'
import IosplitFifoStock from '@/views/collect/IosplitFifoStock.vue'
// 导入器械相关工位上货页面
1 month ago
import DevicesIoCreateOrderOut from '@/views/collect/device/DevicesIoCreateOrder.vue'
import DevicesIoSplitFifoRemove from '@/views/collect/device/DevicesIoSplitFifoRemove.vue'
import DevicesIoSplitFifoRemind from '@/views/collect/device/DevicesIoSplitFifoRemind.vue'
import DevicesIoSplitFifoCode from '@/views/collect/device/DevicesIoSplitFifoCode.vue'
import DevicesIoDestroyOrder from '@/views/collect/device/DevicesIoDestroyOrder.vue'
import DevicesIoCreateOrderReturn from '@/views/collect/device/DevicesIoCreateOrder.vue'
import DevicesIoCreateOrderOutRecord from '@/views/collect/device/DevicesIoCreateOrderOutRecord.vue'
import DevicesDealOrderPre from '@/views/collect/device/DevicesDealOrderPre.vue'
import { listPage, switchWorkplaceStatus } from '@/api/basic/workPlace/sysWorkplaceManage'
import {
filterListByWorkplace,
} from '@/api/basic/workPlace/sysWorkplaceDocuments'
import { EventBus } from '@/eventBus'
import DevicesDealOrder from '@/views/collect/device/DevicesDealOrder.vue'
import DevicesIocCollectOrderCheckCode from '@/views/collect/device/DevicesIocCollectOrderCheckCode.vue'
import DevicesCollectOrderAllot from '@/views/collect/device/DevicesCollectOrderAllot.vue'
import DevicesCollectOrderEnd from '@/views/collect/device/DevicesCollectOrderEnd.vue'
import DevicesCollectOrderUpload from '@/views/collect/device/DevicesCollectOrderUpload.vue'
export default {
components: {
7 months ago
DealOrder,
1 month ago
DealOrderPre,
ConfirmDrugDealOrder,
7 months ago
IoCreateOrderReturn,
IoCreateOrderOut,
ioSplitFifoCode,
CollectOrderAllot,
CollectOrderEnd,
7 months ago
CollectOrderUpload,
IoDestroyOrder,
IocCollectOrderCheckCode,
IoCreateOrderOutRecord,
IocCollectOrderVerify,
IoSplitFifoRemove,
IoSplitCreateOrder,
IosplitFifoStock,
//器械页面
DevicesDealOrder,
DevicesIocCollectOrderCheckCode,
DevicesCollectOrderAllot,
DevicesCollectOrderEnd,
DevicesCollectOrderUpload,
DevicesIoCreateOrderOut,
DevicesIoSplitFifoRemove,
DevicesIoSplitFifoRemind,
DevicesIoSplitFifoCode,
DevicesIoDestroyOrder,
DevicesIoCreateOrderReturn,
DevicesIoCreateOrderOutRecord,
1 month ago
DevicesDealOrderPre
},
name: 'CollectOrderTabs',
data() {
return {
7 months ago
isContentVisible: false, // 控制内容是否显示
7 months ago
showContextMenu: false, // 控制上下文菜单的显示
1 month ago
contextMenuPosition: { x: 0, y: 0 }, // 上下文菜单的位置
selectWorkplaceClosrrButDisabled: false,
selectWorkplaceeDisabled: false,
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,
// userId : this.$store.getters.adminId,
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',
fifoSplitTag: 0
}
},
{
number: 2,
title: '工位退货',
7 months ago
name: 'IoCreateOrderReturn',
component: IoCreateOrderReturn,
// 假设你需要传递的参数
componentProps: {
1 month ago
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,
1 month ago
title: '上货推荐',
7 months ago
name: 'IoSplitFifoRemind',
component: IoSplitFifoRemind,
// 假设你需要传递的参数
componentProps: {}
},
{
number: 9,
title: '取药确认',
name: 'ConfirmDrugDealOrder',
component: ConfirmDrugDealOrder,
// 假设你需要传递的参数
componentProps: {}
},
{
number: 10,
title: '单据审核',
name: 'IocCollectOrderCheckCode',
component: IocCollectOrderCheckCode,
// 假设你需要传递的参数
componentProps: {}
},
{
number: 11,
title: '单据校验',
name: 'IocCollectOrderVerify',
component: IocCollectOrderVerify,
// 假设你需要传递的参数
componentProps: {}
},
{
number: 12,
title: '上货记录',
name: 'IoCreateOrderOutRecord',
component: IoCreateOrderOutRecord,
// 假设你需要传递的参数
componentProps: {}
},
{
number: 13,
title: '工位剔除',
name: 'IoSplitFifoRemove',
component: IoSplitFifoRemove,
// 假设你需要传递的参数
componentProps: {
1 month ago
message: ''
}
},
1 month ago
{
number: 14,
title: '处理预验收',
name: 'DealOrderPre',
component: DealOrderPre,
// 假设你需要传递的参数
1 month ago
componentProps: {}
1 month ago
},
{
number: 15,
title: '拆零上货',
name: 'IoSplitCreateOrder',
component: IoSplitCreateOrder,
// 假设你需要传递的参数
componentProps: {
fromSplitType: 'out',
fifoSplitTag: 1
}
},
{
number: 16,
title: '整取上货',
name: 'IoFullCreateOrder',
component: IoFullCreateOrder,
// 假设你需要传递的参数
componentProps: {
fromSplitType: 'out',
fifoSplitTag: 2
}
},
{
number: 17,
title: '库存预览',
name: 'IosplitFifoStock',
component: IosplitFifoStock,
// 假设你需要传递的参数
componentProps: {
}
},
//器械页面
{
1 month ago
number: 10000,
title: '处理单据',
name: 'DevicesDealOrder',
component: DevicesDealOrder,
// 假设你需要传递的参数
componentProps: {
// title: '这是单据的标题',
}
},
{
1 month ago
number: 1000,
1 month ago
title: '单据审核',
name: 'DevicesIocCollectOrderCheckCode',
component: DevicesIocCollectOrderCheckCode,
// 假设你需要传递的参数
componentProps: {
// title: '这是单据的标题',
}
},
{
1 month ago
number: 400,
1 month ago
title: '待处理单',
name: 'DevicesCollectOrderAllot',
component: DevicesCollectOrderAllot,
// 假设你需要传递的参数
componentProps: {}
},
{
1 month ago
number: 500,
1 month ago
title: '已完成单',
name: 'DevicesCollectOrderEnd',
component: DevicesCollectOrderEnd,
// 假设你需要传递的参数
componentProps: {}
},
{
1 month ago
number: 600,
1 month ago
title: '单据上传',
name: 'DevicesCollectOrderUpload',
component: DevicesCollectOrderUpload,
// 假设你需要传递的参数
componentProps: {}
},
{
1 month ago
number: 100,
title: '工位上货',
name: 'DevicesIoCreateOrderOut',
component: DevicesIoCreateOrderOut,
// 假设你需要传递的参数
componentProps: {
fromSplitType: 'out',
fifoSplitTag: 0
}
},
{
number: 1300,
1 month ago
title: '工位剔除',
name: 'DevicesIoSplitFifoRemove',
component: DevicesIoSplitFifoRemove,
// 假设你需要传递的参数
componentProps: {
1 month ago
message: ''
}
},
{
number: 800,
1 month ago
title: '上货推荐',
name: 'DevicesIoSplitFifoRemind',
component: DevicesIoSplitFifoRemind,
// 假设你需要传递的参数
componentProps: {}
},
{
number: 300,
1 month ago
title: '工位库存',
name: 'DevicesIoSplitFifoCode',
component: DevicesIoSplitFifoCode,
// 假设你需要传递的参数
componentProps: {}
},
{
number: 700,
1 month ago
title: '拆零管理',
name: 'DevicesIoDestroyOrder',
component: DevicesIoDestroyOrder,
// 假设你需要传递的参数
componentProps: {}
},
{
number: 200,
1 month ago
title: '工位退货',
name: 'DevicesIoCreateOrderReturn',
component: DevicesIoCreateOrderReturn,
// 假设你需要传递的参数
componentProps: {
1 month ago
fromSplitType: 'return'
}
},
{
number: 1200,
1 month ago
title: '上货记录',
name: 'DevicesIoCreateOrderOutRecord',
component: DevicesIoCreateOrderOutRecord,
// 假设你需要传递的参数
componentProps: {}
},
{
number: 1400,
1 month ago
title: '处理预验收',
name: 'DevicesDealOrderPre',
component: DevicesDealOrderPre,
// 假设你需要传递的参数
1 month ago
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,
4 months ago
inAndOutType: 0,
6 months ago
workPlaceClass: 1,
resetKeys: {},
sendData: '',
//默认业务类型 为药品 sys_workplace_document
productType: 2,
//作业模式
jobMode : 0,
}
},
methods: {
7 months ago
toggleContent() {
// 切换isContentVisible的值
1 month ago
this.isContentVisible = !this.isContentVisible
7 months ago
//判断是否展开 展开 就查全部/折叠就是 常用的
// todo 2024/09/09
if (this.isContentVisible) {
7 months ago
this.busQuery.isPopular = 0
} else {
7 months ago
this.busQuery.isPopular = 1
}
this.getWorkBindBusTypes(this.formData.workplaceId)
},
7 months ago
toggleWorkplaceStatus() {
if (this.formData.workplaceStatus == 0) {
7 months ago
this.formData.workplaceStatus = 1
} else {
7 months ago
this.formData.workplaceStatus = 0
}
switchWorkplaceStatus(this.formData).then(resp => {
if (resp.code == 20000) {
1 month ago
this.$message.success('切换成功!')
7 months ago
} else {
7 months ago
this.$message.error(resp.message)
if (this.formData.workplaceStatus == 0) {
7 months ago
this.formData.workplaceStatus = 1
} else {
7 months ago
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
},
toggleWorkplace() {
//切换业务时 可以有关闭按钮展示
this.selectWorkplaceClosrrButDisabled = true
this.selectWorkplaceeDisabled = true
},
7 months ago
selectBusType(info) {
let val = info.documentTypeCode
7 months ago
this.formData.busType = val
1 month ago
let newQuery = { ...this.$route.query }
delete newQuery.billNo
7 months ago
newQuery.busType = val
1 month ago
this.$router.push({ query: newQuery, path: this.$route.path })
this.formData.busName = info.busName
this.autoTag = info.autoTag
7 months ago
this.editableTabs = []
1 month ago
if (this.productType == 2) {
this.clickMenuItem(10)
1 month ago
} else {
1 month ago
this.clickMenuItem(1000)
}
1 month ago
this.showChild = false
7 months ago
this.$nextTick(() => {
1 month ago
this.showChild = true
})
7 months ago
this.selectBusTypeDisabled = false
7 months ago
this.selectBusTypeClosrrButDisabled = false
7 months ago
},
selectWorkplace(info) {
let val = info.workplaceId
this.formData.workplaceId = val
1 month ago
let newQuery = { ...this.$route.query }
delete newQuery.billNo
newQuery.workplaceId = val
1 month ago
delete newQuery.workPlaceClass
newQuery.workPlaceClass = info.workPlaceClass
1 month ago
this.$router.push({ query: newQuery, path: this.$route.path })
this.formData.workplaceName = info.workplaceName
this.editableTabs = []
1 month ago
if (this.productType == 2) {
this.clickMenuItem(1)
} else {
this.clickMenuItem(100)
}
1 month ago
this.showChild = false
this.$nextTick(() => {
1 month ago
this.showChild = true
})
this.selectWorkplaceClosrrButDisabled = false
this.selectWorkplaceeDisabled = false
1 month ago
location.reload()
},
7 months ago
parentMethod(data) {
const foundTab = this.findAllTabByName(data)
this.clickMenuItem(foundTab.number)
1 month ago
this.showChild = false
7 months ago
this.$nextTick(() => {
1 month ago
this.showChild = true
})
7 months ago
},
upodateMenuActive(tab, event) {
const foundTab = this.findTabByName(tab.name)
if (foundTab) {
// 如果找到了,执行一些操作
this.menuActive = foundTab.number
// 上面这个呀呀呀呀呀呀呀呀
1 month ago
this.$set(this.resetKeys, foundTab.name, Date.now())
this.$store.commit('tabActive/SET_MENU_ACTIVE', foundTab.number)
}
},
clickMenuItem(val) {
//分两种 一种已存在 一种未存在
1 month ago
let item = this.componentTables.find(tab => tab.number === val)
1 month ago
if (val == 13 || val == 1300) {
1 month ago
//如果是第一次 剔除页面没有创建 需要组件参数传递过去
item.componentProps.message = this.sendData
}
const foundTab = this.findTabByName(item.name)
if (foundTab) {
// 如果找到了,执行一些操作
this.editableTabsValue = foundTab.name
1 month ago
this.$set(this.resetKeys, foundTab.name, Date.now())
7 months ago
this.menuActive = foundTab.number
1 month ago
this.$store.commit('tabActive/SET_MENU_ACTIVE', foundTab.number)
// 将消息传递给 foundTab
1 month ago
if (val == 13 || val == 1300) {
1 month ago
//tab格子已经被添加 剔除页面已经被创建 发送槽位编码过去
1 month ago
EventBus.$emit('sendData', { message: this.sendData })
}
} 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
1 month ago
this.$store.commit('tabActive/SET_MENU_ACTIVE', 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
1 month ago
this.$store.commit('tabActive/SET_MENU_ACTIVE', 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,
1 month ago
workPlaceClass: this.$route.query.workPlaceClass,
7 months ago
page: 1,
1 month ago
limit: 100
7 months ago
}
listPage(query).then((res) => {
1 month ago
this.curWorkPlaces = res.data.list || []
if (this.$route.query.workplaceId != null) {
1 month ago
let item = this.curWorkPlaces.find(item => item.workplaceId == this.$route.query.workplaceId)
this.formData.workplaceName = item.workplaceName
this.formData.workplaceStatus = item.workplaceStatus
1 month ago
} else if (this.curWorkPlaces.length == 1 && this.formData.workPlaceCode == null) {
this.formData.workPlaceCode = this.curWorkPlaces[0].workplaceId
1 month ago
// this.workPlaceCodeChange(this.formData.workPlaceCode)
}
7 months ago
})
},
getWorkBindBusTypes(workplaceId) {
this.busQuery.workplaceCode = workplaceId
filterListByWorkplace(this.busQuery).then(res => {
7 months ago
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)
1 month ago
this.formData.busName = busType.busName
this.autoTag = busType.autoTag
this.inAndOutType = busType.inAndOutType
} else if (this.busTypeList.length == 1) {
this.formData.busType = this.busTypeList[0].documentTypeCode
1 month ago
this.autoTag = this.busTypeList[0].autoTag
this.inAndOutType = this.busTypeList[0].inAndOutType
this.$router.push({
query: { ...this.$route.query, busType: this.formData.busType },
path: this.$route.path
})
this.selectBusTypeDisabled = false
1 month ago
this.formData.busName = this.busTypeList.find(item => item.documentTypeCode == this.formData.busType).busName
} else {
this.selectBusTypeDisabled = true
this.formData.busType = null
}
7 months ago
1 month ago
if (this.inAndOutType == 1) {
1 month ago
if (this.productType == 2) {
this.closeAllTabs()
1 month ago
this.editableTabsValue = 'IocCollectOrderCheckCode'
this.menuActive = 10
this.editableTabs = [{
4 months ago
number: 10,
title: '单据审核',
name: 'IocCollectOrderCheckCode',
component: IocCollectOrderCheckCode,
// 假设你需要传递的参数
componentProps: {}
}
1 month ago
]
} else {
this.closeAllTabs()
1 month ago
this.editableTabsValue = 'DevicesIocCollectOrderCheckCode'
1 month ago
this.menuActive = 1000
1 month ago
this.editableTabs = [{
1 month ago
number: 1000,
1 month ago
title: '单据审核',
name: 'DevicesIocCollectOrderCheckCode',
component: DevicesIocCollectOrderCheckCode,
// 假设你需要传递的参数
componentProps: {}
}
1 month ago
]
}
4 months ago
}
7 months ago
}
return
})
},
7 months ago
handleContextMenu() {
1 month ago
this.showContextMenu = true
7 months ago
},
handleTabContextMenu(event, tab) {
1 month 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() {
1 month ago
this.showContextMenu = false
7 months ago
// this.contextMenuStyle.display = 'none'; // 隐藏上下文菜单
7 months ago
},
7 months ago
closeCurrentTab(index) {
7 months ago
// 关闭当前标签页的逻辑
1 month 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
// ...
1 month ago
this.closeContextMenu()
7 months ago
},
7 months ago
closeAllTabs() {
7 months ago
// 关闭所有标签页的逻辑
1 month ago
this.editableTabs = []
this.editableTabsValue = ''
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`,
1 month ago
zIndex: 1000 // 确保它在其他内容之上
7 months ago
// 其他样式...
1 month ago
}
}
},
created() {
1 month ago
this.workPlaceClass = this.$route.query.workPlaceClass
1 month ago
this.productType = this.$route.query.productType
this.jobMode = this.$route.query.jobMode
1 month ago
if (this.workPlaceClass == 2) {
this.closeAllTabs()
1 month ago
if (this.productType == 2){
if (this.jobMode == 0){
this.editableTabsValue = 'IoCreateOrderOut'
this.menuActive = 1,
this.editableTabs = [{
number: 1,
title: '工位上货',
name: 'IoCreateOrderOut',
component: IoCreateOrderOut,
// 假设你需要传递的参数
componentProps: {
fromSplitType: 'out',
fifoSplitTag:0
}
1 month ago
}
]
}
if (this.jobMode == 1){
this.editableTabsValue = 'IoSplitCreateOrder'
this.menuActive = 15,
this.editableTabs = [{
number: 15,
title: '拆零上货',
name: 'IoSplitCreateOrder',
component: IoSplitCreateOrder,
// 假设你需要传递的参数
componentProps: {
fromSplitType: 'out',
fifoSplitTag:1
}
}
]
}
1 month ago
}else if (this.productType == 1){
this.editableTabsValue = 'DevicesIoCreateOrderOut'
this.menuActive = 100,
this.editableTabs = [{
number: 100,
1 month ago
title: '工位上货',
1 month ago
name: 'DevicesIoCreateOrderOut',
component: DevicesIoCreateOrderOut,
// 假设你需要传递的参数
componentProps: {
fromSplitType: 'out',
fifoSplitTag: 0
1 month ago
}
}
]
}
1 month ago
}else if (this.workPlaceClass == 1 && this.productType == 1 ) {
this.closeAllTabs()
this.editableTabsValue = 'DevicesDealOrder'
this.menuActive = 10000,
this.editableTabs = [{
number: 10000,
title: '处理单据',
name: 'DevicesDealOrder',
component: DevicesDealOrder,
// 假设你需要传递的参数
componentProps: {
// title: '这是单据的标题',
}
}
]
}
4 weeks ago
this.findCurWorkPlaces(this.$route.query.workplaceId)
if (this.$route.query.workplaceId != null) {
this.isLinkDisabled = true
1 month ago
this.formData.workPlaceCode = Number(this.$route.query.workplaceId)
this.formData.workplaceId = Number(this.$route.query.workplaceId)
if (this.workPlaceClass == 1) {
this.getWorkBindBusTypes(this.formData.workPlaceCode)
} else if (this.workPlaceClass == 2) {
this.busQuery.workplaceCode = this.formData.workPlaceCode
filterListByWorkplace(this.busQuery).then(res => {
if (res.code == 20000) {
this.busTypeList = res.data.list
this.busTypeTotal = res.data.total
}
return
})
}
}
},
mounted() {
EventBus.$on('update-data', (data) => {
1 month ago
//接受上货页面 传递过来的 槽位编码
this.sendData = data.message
1 month ago
})
},
beforeDestroy() {
1 month ago
EventBus.$off('update-data')
}
}
</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;
position: fixed;
7 months ago
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>