38 changed files with 3521 additions and 745 deletions
@ -0,0 +1,18 @@ |
|||||||
|
<template> |
||||||
|
<BasicContainer :option="option"> |
||||||
|
<template #head>123</template> |
||||||
|
|
||||||
|
<template #body>333</template> |
||||||
|
</basicContainer> |
||||||
|
</template> |
||||||
|
|
||||||
|
<script setup lang="ts"> |
||||||
|
import { ref, reactive } from 'vue'; |
||||||
|
const option = reactive({ |
||||||
|
title: '提货批次列表', |
||||||
|
haveData: true |
||||||
|
}) |
||||||
|
</script> |
||||||
|
|
||||||
|
<style lang="scss" scoped> |
||||||
|
</style> |
@ -0,0 +1,693 @@ |
|||||||
|
<template> |
||||||
|
<!-- 顶部导航栏 --> |
||||||
|
<u-navbar title="库位查询" placeholder :autoBack="true" leftIconSize='35' bgColor='#d3832a' leftIconColor='#ffffff' |
||||||
|
titleStyle='color:#ffffff'></u-navbar> |
||||||
|
|
||||||
|
<!-- 头部 --> |
||||||
|
<!-- <view class="tabBar_top"> |
||||||
|
<view @click="handleTabBarState(1)" :class="{'active': tabBarCode === 1}"> |
||||||
|
库位查询 |
||||||
|
</view> |
||||||
|
<view @click="handleTabBarState(2)" :class="{'active': tabBarCode === 2}"> |
||||||
|
托盘查询 |
||||||
|
</view> |
||||||
|
<view @click="handleTabBarState(3)" :class="{'active': tabBarCode === 3}"> |
||||||
|
订单查询 |
||||||
|
</view> |
||||||
|
</view> --> |
||||||
|
|
||||||
|
<view class="container"> |
||||||
|
<!-- 顶部搜索栏 --> |
||||||
|
<view class="header-search"> |
||||||
|
<view class="search"> |
||||||
|
<input class="searchInput" v-model="scancode" type="text"> |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class="search"> |
||||||
|
<view class="searchType" @click="scandata"> |
||||||
|
搜索 |
||||||
|
</view> |
||||||
|
|
||||||
|
</view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class="orderInfo"> |
||||||
|
<!-- 库位数据 --> |
||||||
|
<view class="orderInfo_title"> |
||||||
|
<view class=""> |
||||||
|
<text class="row_title1"> |
||||||
|
库位: |
||||||
|
</text> |
||||||
|
{{info.positionCode || '暂无数据'}} |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class="orderInfo_title_row"> |
||||||
|
<view class=""> |
||||||
|
<view class="row_title1"> |
||||||
|
托盘名称: |
||||||
|
</view> |
||||||
|
<view> |
||||||
|
{{info.trayInfo.palletName || '暂无数据'}} |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class=""> |
||||||
|
<view class="row_title2"> |
||||||
|
托盘码: |
||||||
|
</view> |
||||||
|
<view class=""> |
||||||
|
{{info.trayInfo.palletCode || '暂无数据'}} |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class="orderInfo_title_row"> |
||||||
|
<view class=""> |
||||||
|
<text class="row_title1"> |
||||||
|
包件数: |
||||||
|
</text> |
||||||
|
{{info.totalNum || 0}} |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class=""> |
||||||
|
<text class="row_title2"> |
||||||
|
订单包件总数: |
||||||
|
</text> |
||||||
|
{{info.orderTotalNum || 0}} |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class="orderInfo_title_row"> |
||||||
|
<view class=""> |
||||||
|
<text class="row_title1"> |
||||||
|
库存品数: |
||||||
|
</text> |
||||||
|
{{info.stockNum || 0}} |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class=""> |
||||||
|
<text class="row_title2"> |
||||||
|
库存品订单总数: |
||||||
|
</text> |
||||||
|
{{info.stockTotalNum || 0}} |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class="title"> |
||||||
|
<view @click="handleTabBarState(1)" :class="{'active': tabBarCode === 1}"> |
||||||
|
定制品 |
||||||
|
</view> |
||||||
|
<view @click="handleTabBarState(2)" :class="{'active': tabBarCode === 2}"> |
||||||
|
零担 |
||||||
|
</view> |
||||||
|
<view @click="handleTabBarState(3)" :class="{'active': tabBarCode === 3}"> |
||||||
|
库存品 |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<!-- 定制品 --> |
||||||
|
<view class="packagesList" v-if="tabBarCode === 1"> |
||||||
|
<!-- 控件 --> |
||||||
|
<view class="control"> |
||||||
|
<view v-if="!isBatchOperation"> |
||||||
|
<view class="batchOperationBtn" @click="isBatchOperation = true">批量操作</view> |
||||||
|
</view> |
||||||
|
<view v-else style="display: flex;"> |
||||||
|
<view class="batchOperationBtn" @click="batchPrint">打印</view> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<scroll-view scroll-y="true" style="height: 60vh; margin-top: 10px;"> |
||||||
|
<uni-table type="selection" border stripe emptyText="暂无更多数据" |
||||||
|
@selection-change="({detail: {index}})=> selectionChange(index, 'order')"> |
||||||
|
<!-- 表头行 --> |
||||||
|
<uni-tr> |
||||||
|
<uni-th align="left">包条码</uni-th> |
||||||
|
<uni-th align="left">合同号</uni-th> |
||||||
|
<uni-th align="left">运单号</uni-th> |
||||||
|
<uni-th align="left">仓库</uni-th> |
||||||
|
<uni-th align="left">数量</uni-th> |
||||||
|
</uni-tr> |
||||||
|
<!-- 表格数据行 --> |
||||||
|
<block v-for="item in packageList"> |
||||||
|
<uni-tr> |
||||||
|
<!-- 包条码 --> |
||||||
|
<uni-td>{{item.orderPackageCode}}</uni-td> |
||||||
|
<!-- 合同号 --> |
||||||
|
<uni-td>{{item.orderCode}}</uni-td> |
||||||
|
<!-- 运单号 --> |
||||||
|
<uni-td>{{item.waybillNo}}</uni-td> |
||||||
|
<!-- 仓库 --> |
||||||
|
<uni-td>{{item.warehouseName}}</uni-td> |
||||||
|
<!-- 数量 --> |
||||||
|
<uni-td>{{item.num}}</uni-td> |
||||||
|
</uni-tr> |
||||||
|
</block> |
||||||
|
|
||||||
|
</uni-table> |
||||||
|
</scroll-view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<!-- 零担 --> |
||||||
|
<view class="packagesList" v-else-if="tabBarCode === 2"> |
||||||
|
<scroll-view scroll-y="true" style="height: 60vh; margin-top: 10px;"> |
||||||
|
<uni-table type="selection" border stripe emptyText="暂无更多数据" |
||||||
|
@selection-change="({detail: {index}})=>selectionChange(index, 'zero')"> |
||||||
|
<!-- 表头行 --> |
||||||
|
<uni-tr> |
||||||
|
<uni-th align="left">运单号</uni-th> |
||||||
|
<uni-th align="left">合同号</uni-th> |
||||||
|
<uni-th align="left">仓库</uni-th> |
||||||
|
<uni-th align="center">数量</uni-th> |
||||||
|
</uni-tr> |
||||||
|
<!-- 表格数据行 --> |
||||||
|
<block v-for="item in zeroList"> |
||||||
|
<uni-tr> |
||||||
|
<!-- 运单号 --> |
||||||
|
<uni-td>{{item.waybillNo}}</uni-td> |
||||||
|
<!-- 合同号 --> |
||||||
|
<uni-td>{{item.orderCode}}</uni-td> |
||||||
|
<!-- 仓库 --> |
||||||
|
<uni-td>{{item.warehouseName}}</uni-td> |
||||||
|
<!-- 数量 --> |
||||||
|
<uni-td align="center">{{item.num}}</uni-td> |
||||||
|
</uni-tr> |
||||||
|
</block> |
||||||
|
</uni-table> |
||||||
|
</scroll-view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<!-- 库存品 --> |
||||||
|
<view class="packagesList" v-else-if="tabBarCode === 3"> |
||||||
|
<scroll-view scroll-y="true" style="height: 60vh; margin-top: 10px;"> |
||||||
|
<uni-table type="selection" border stripe emptyText="暂无更多数据" |
||||||
|
@selection-change="({detail: {index}})=>selectionChange(index, 'stock')"> |
||||||
|
<!-- 表头行 --> |
||||||
|
<uni-tr> |
||||||
|
<uni-th align="left">批次号</uni-th> |
||||||
|
<uni-th align="left">物料编码</uni-th> |
||||||
|
<uni-th align="left">物料名称</uni-th> |
||||||
|
<uni-th align="left">商场名称</uni-th> |
||||||
|
<uni-th align="center">仓库</uni-th> |
||||||
|
<uni-th align="center">在库数</uni-th> |
||||||
|
</uni-tr> |
||||||
|
<!-- 表格数据行 --> |
||||||
|
<block v-for="item in stockList"> |
||||||
|
<uni-tr> |
||||||
|
<!-- 批次号 --> |
||||||
|
<uni-td>{{item.incomingBatch}}</uni-td> |
||||||
|
<!-- 物料编码 --> |
||||||
|
<uni-td>{{item.materialCode}}</uni-td> |
||||||
|
<!-- 物料名称 --> |
||||||
|
<uni-td>{{item.materialName}}</uni-td> |
||||||
|
<!-- 商场名称 --> |
||||||
|
<uni-td>{{item.marketName}}</uni-td> |
||||||
|
<!-- 仓库 --> |
||||||
|
<uni-td>{{item.warehouseName}}</uni-td> |
||||||
|
<!-- 数量 --> |
||||||
|
<uni-td align="center">{{item.num}}</uni-td> |
||||||
|
</uni-tr> |
||||||
|
</block> |
||||||
|
</uni-table> |
||||||
|
</scroll-view> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
<tiplist ref="tiplists"></tiplist> |
||||||
|
<!-- #ifdef APP --> |
||||||
|
<saomiao2 :ishidestop="scanState !== 0"></saomiao2> |
||||||
|
<!-- #endif --> |
||||||
|
<BluetoothList ref="bluetoothList"></BluetoothList> |
||||||
|
</template> |
||||||
|
|
||||||
|
<script lang="ts" setup> |
||||||
|
import { ref, reactive, shallowRef, watch, nextTick, computed } from 'vue'; |
||||||
|
import { |
||||||
|
onShow, |
||||||
|
onHide, |
||||||
|
onLoad, |
||||||
|
onReachBottom, |
||||||
|
onPullDownRefresh |
||||||
|
} from '@dcloudio/uni-app' |
||||||
|
import utils from '@/utils/utils.js'; |
||||||
|
import { |
||||||
|
postFindAllocationData, |
||||||
|
BatchPrintPackages |
||||||
|
} from '@/api/user.js' |
||||||
|
import useBluetoothStore from '@/store/useBluetoothStore.js'; |
||||||
|
import useSystemSettingsStore from '@/store/useSystemSettingsStore'; |
||||||
|
import { storeToRefs } from 'pinia'; |
||||||
|
const { scanState } = storeToRefs(useSystemSettingsStore()) |
||||||
|
const bluetoothList = ref(null) |
||||||
|
const bluetoothStore = useBluetoothStore() |
||||||
|
const { bluetoothInfo } = storeToRefs(bluetoothStore) |
||||||
|
|
||||||
|
// 订单详情 |
||||||
|
const dataInfo = shallowRef<any>({}) |
||||||
|
|
||||||
|
/** 是否开启批量操作 */ |
||||||
|
const isBatchOperation = ref<Boolean>(false) |
||||||
|
|
||||||
|
/** 是否显示定制品 */ |
||||||
|
const showArticleMadeToOrder = ref<Boolean>(true) |
||||||
|
|
||||||
|
/** 扫码码值 */ |
||||||
|
const scancode = ref<string>('') |
||||||
|
|
||||||
|
/** 包件列表 */ |
||||||
|
const packageList = shallowRef([]) |
||||||
|
|
||||||
|
/** 零担列表 */ |
||||||
|
const zeroList = shallowRef([]) |
||||||
|
|
||||||
|
/** 库存品列表 */ |
||||||
|
const stockList = shallowRef([]) |
||||||
|
|
||||||
|
/** 详情 */ |
||||||
|
const info = ref<any>({ trayInfo: {} }) |
||||||
|
|
||||||
|
// 订单状态字典 |
||||||
|
const orderStateDictionaries = reactive({ |
||||||
|
'10': '部分入库', |
||||||
|
'20': '已入库', |
||||||
|
'30': '部分出库', |
||||||
|
'40': '已出库', |
||||||
|
'50': '部分装车', |
||||||
|
'60': '已装车', |
||||||
|
'70': '部分签收', |
||||||
|
'80': '已签收', |
||||||
|
}) |
||||||
|
|
||||||
|
/** tabBar 激活 */ |
||||||
|
const tabBarCode = ref(1) |
||||||
|
|
||||||
|
/** 修改物料表单 */ |
||||||
|
const form = ref({}) |
||||||
|
|
||||||
|
/** 复选框选中的数据 */ |
||||||
|
const selectionList = ref([]) |
||||||
|
|
||||||
|
// 组件实例 |
||||||
|
const tiplists = ref(null) |
||||||
|
|
||||||
|
|
||||||
|
onLoad(() => { |
||||||
|
// #ifdef APP |
||||||
|
utils.ttsspke('库位查询, 请扫描或输入库位码') |
||||||
|
// #endif |
||||||
|
}) |
||||||
|
|
||||||
|
// 开启监听扫描 |
||||||
|
onShow(async () => { |
||||||
|
// #ifdef APP |
||||||
|
uni.$off('scancodedate') |
||||||
|
uni.$on('scancodedate', function (code) { |
||||||
|
if (code) { |
||||||
|
scancode.value = code |
||||||
|
|
||||||
|
scandata() |
||||||
|
} |
||||||
|
}) |
||||||
|
// #endif |
||||||
|
}) |
||||||
|
|
||||||
|
onPullDownRefresh(() => { |
||||||
|
const timer = setTimeout(() => { |
||||||
|
dataInfo.value = {} |
||||||
|
scancode.value = '' |
||||||
|
packageList.value = [] |
||||||
|
|
||||||
|
uni.stopPullDownRefresh() |
||||||
|
clearTimeout(timer) |
||||||
|
}, 300) |
||||||
|
}) |
||||||
|
|
||||||
|
async function scandata() { |
||||||
|
const res = await postFindAllocationData({ allocationId: scancode.value }) |
||||||
|
console.log('res :>> ', res); |
||||||
|
const { code, data } = res |
||||||
|
|
||||||
|
if (code !== 200 || !data) return |
||||||
|
|
||||||
|
// 库位信息 |
||||||
|
info.value = data.updownTypeEntity || {} |
||||||
|
|
||||||
|
// 库位托盘信息 |
||||||
|
info.value.trayInfo = data.trayEntity || {} |
||||||
|
|
||||||
|
// 定制品 |
||||||
|
packageList.value = data.packageList |
||||||
|
|
||||||
|
// 零担 |
||||||
|
zeroList.value = data.zeroOrderList |
||||||
|
|
||||||
|
// 库存品 |
||||||
|
stockList.value = data.stockOrderList |
||||||
|
} |
||||||
|
|
||||||
|
/** 设置tabBar激活状态 */ |
||||||
|
const handleTabBarState = (code) => { |
||||||
|
selectionList.value = [] |
||||||
|
tabBarCode.value = code |
||||||
|
} |
||||||
|
|
||||||
|
/** 复选框改变时 */ |
||||||
|
const selectionChange = (list : [], type : string) => { |
||||||
|
console.log('list :>> ', list); |
||||||
|
selectionList.value = list |
||||||
|
} |
||||||
|
|
||||||
|
/** 打印 */ |
||||||
|
const batchPrint = async () => { |
||||||
|
if (selectionList.value.length === 0) return uni.showToast({ |
||||||
|
title: '最少选择一条数据', |
||||||
|
icon: 'none' |
||||||
|
}) |
||||||
|
|
||||||
|
const _idsArr = [] |
||||||
|
|
||||||
|
for (let i = 0; i < selectionList.value.length; i++) { |
||||||
|
// selectionList内存储的是被选中的索引 |
||||||
|
const index = selectionList.value[i] |
||||||
|
_idsArr.push(packageList.value[index].packageId) |
||||||
|
} |
||||||
|
|
||||||
|
const idsValue = _idsArr.join(',') |
||||||
|
|
||||||
|
const res = await BatchPrintPackages(idsValue) |
||||||
|
const { code, data } = res |
||||||
|
if (code !== 200) return |
||||||
|
console.log('res :>> ', res); |
||||||
|
tiplists.value.setdetails({ |
||||||
|
title: '请选择需要打印的包条码', |
||||||
|
isshow: true, |
||||||
|
tipstate: 2, |
||||||
|
list: [], |
||||||
|
inputtext: '', |
||||||
|
confirmTxt: '确认选择', |
||||||
|
isonecheck: true, |
||||||
|
success: () => { |
||||||
|
// if (deta.checklist.length == 0) { |
||||||
|
// uni.showToast({ |
||||||
|
// title: '请选择包条码', |
||||||
|
// icon: 'none' |
||||||
|
// }) |
||||||
|
// return |
||||||
|
// } |
||||||
|
console.log('data :>> ', data); |
||||||
|
// #ifdef APP |
||||||
|
if (!bluetoothInfo.value.name) return bluetoothList.value.setdetails({ isshow: true }) |
||||||
|
let _isReturn = false |
||||||
|
data.map(item => { |
||||||
|
if (_isReturn) return |
||||||
|
let text = '! 0 200 200 330 1\r\n' |
||||||
|
text += 'SETBOLD 1\r\n' |
||||||
|
text += `T 56 0 0 0 ${item.orderCode}\r\n` |
||||||
|
text += 'LINE 0 50 420 50 3\r\n' |
||||||
|
text += `T 55 0 0 60 客户\r\n` |
||||||
|
text += 'LINE 40 50 40 110 3\r\n' |
||||||
|
text += `T 55 0 50 60 ${item.customerName}\r\n` |
||||||
|
text += 'LINE 40 80 420 80 3\r\n' |
||||||
|
text += `T 55 0 50 90 ${item.customerAddress}\r\n` |
||||||
|
text += 'LINE 0 110 420 110 3\r\n' |
||||||
|
text += `T 55 0 0 120 物料\r\n` |
||||||
|
text += 'LINE 40 110 40 140 3\r\n' |
||||||
|
text += `T 55 0 50 120 ${item.materialName || item.category}\r\n` |
||||||
|
text += 'LINE 0 140 420 140 3\r\n' |
||||||
|
text += 'B QR 150 150 M 2 U 4\r\n' |
||||||
|
text += `MA,${item.qrCode}\r\n` |
||||||
|
text += 'ENDQR\r\n' |
||||||
|
text += `T 55 0 140 260 ${item.qrCode}\r\n` |
||||||
|
text += 'FORM\r\n' |
||||||
|
text += 'PRINT\r\n' |
||||||
|
utils.getbl(bluetoothInfo.value, text).catch(() => { |
||||||
|
bluetoothList.value.setdetails({ isshow: true }) |
||||||
|
_isReturn = true |
||||||
|
}) |
||||||
|
}) |
||||||
|
if (_isReturn) return |
||||||
|
// #endif |
||||||
|
tiplists.value.setdetails({ isshow: false }) |
||||||
|
}, |
||||||
|
cancel: (details) => { |
||||||
|
tiplists.value.setdetails({ isshow: false }) |
||||||
|
}, |
||||||
|
close: (details) => { |
||||||
|
tiplists.value.setdetails({ isshow: false }) |
||||||
|
} |
||||||
|
}) |
||||||
|
} |
||||||
|
</script> |
||||||
|
|
||||||
|
<style lang="scss" scoped> |
||||||
|
.w100 { |
||||||
|
width: 100%; |
||||||
|
} |
||||||
|
|
||||||
|
// 最外层容器 |
||||||
|
.container { |
||||||
|
padding: 20upx; |
||||||
|
font-size: 28upx; // 本页字体大小 |
||||||
|
} |
||||||
|
|
||||||
|
// 顶部tabbar |
||||||
|
.tabBar_top { |
||||||
|
display: flex; |
||||||
|
justify-content: space-around; |
||||||
|
font-size: 32upx; |
||||||
|
// font-weight: bold; |
||||||
|
margin: 10upx 0; |
||||||
|
|
||||||
|
&>view { |
||||||
|
padding: 15upx 0; |
||||||
|
flex: 1; |
||||||
|
text-align: center; |
||||||
|
position: relative; |
||||||
|
// background: #fff; |
||||||
|
transition: all 0.3s; |
||||||
|
border-radius: 10upx; |
||||||
|
|
||||||
|
&::after { |
||||||
|
content: ''; |
||||||
|
display: block; |
||||||
|
position: absolute; |
||||||
|
height: 4upx; |
||||||
|
width: 0; |
||||||
|
background: var(--subjectColor); |
||||||
|
top: 100%; |
||||||
|
left: 50%; |
||||||
|
transition: all 0.5s; |
||||||
|
} |
||||||
|
|
||||||
|
&.active { |
||||||
|
// background: var(--subjectColor); |
||||||
|
// color: #fff; |
||||||
|
|
||||||
|
&::after { |
||||||
|
width: 100%; |
||||||
|
left: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// 顶部搜索栏 |
||||||
|
.header-search { |
||||||
|
height: 60upx; |
||||||
|
padding: 0 0 20upx; |
||||||
|
// border-bottom: 1upx solid #aaa; |
||||||
|
display: flex; |
||||||
|
justify-content: space-between; |
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
.search { |
||||||
|
position: relative; |
||||||
|
|
||||||
|
// 查询结果的列表 |
||||||
|
.searchResultList { |
||||||
|
position: absolute; |
||||||
|
top: 120%; |
||||||
|
width: 100%; |
||||||
|
background: #fff; |
||||||
|
z-index: 80; |
||||||
|
text-align: center; |
||||||
|
line-height: 60upx; |
||||||
|
max-height: 300upx; |
||||||
|
overflow-y: scroll; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// 搜索输入框 |
||||||
|
.searchInput { |
||||||
|
background: #fff; |
||||||
|
width: 500upx; |
||||||
|
height: 100%; |
||||||
|
padding-left: 20upx; |
||||||
|
border: 1upx solid var(--subjectColor); |
||||||
|
border-radius: 30upx; |
||||||
|
} |
||||||
|
|
||||||
|
// 搜索类型 |
||||||
|
.searchType { |
||||||
|
height: 100%; |
||||||
|
display: flex; |
||||||
|
align-items: center; |
||||||
|
padding: 0 40upx; |
||||||
|
background: #fff; |
||||||
|
border: 1upx solid var(--subjectColor); |
||||||
|
border-radius: 10upx; |
||||||
|
color: var(--subjectColor); |
||||||
|
} |
||||||
|
|
||||||
|
// 数据详情 |
||||||
|
.dataInfo { |
||||||
|
display: flex; |
||||||
|
flex-wrap: wrap; |
||||||
|
// border-bottom: 1upx solid #aaa; |
||||||
|
background: #fff; |
||||||
|
} |
||||||
|
|
||||||
|
.dataInfo__item { |
||||||
|
flex: none; |
||||||
|
min-width: 50%; |
||||||
|
max-width: 100%; |
||||||
|
line-height: 60upx; |
||||||
|
display: inline-flex; |
||||||
|
|
||||||
|
.label { |
||||||
|
display: inline-block; |
||||||
|
width: 160upx; |
||||||
|
text-align: right; |
||||||
|
margin-right: 20rpx; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// 订单列表信息 |
||||||
|
.orderInfo { |
||||||
|
// background: #fff; |
||||||
|
margin-top: 10upx; |
||||||
|
|
||||||
|
.orderInfo_title { |
||||||
|
background: #fff; |
||||||
|
font-size: 32upx; |
||||||
|
padding: 15upx; |
||||||
|
border-radius: 5upx; |
||||||
|
box-sizing: border-box; |
||||||
|
box-shadow: 0 0 10px #acc, 3px 3px #abb; |
||||||
|
font-size: 28upx; |
||||||
|
|
||||||
|
.row_title1 { |
||||||
|
display: inline-block; |
||||||
|
min-width: 140upx; |
||||||
|
} |
||||||
|
|
||||||
|
.row_title2 { |
||||||
|
display: inline-block; |
||||||
|
min-width: 200upx; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
.orderInfo_title_row { |
||||||
|
display: flex; |
||||||
|
margin-top: 10upx; |
||||||
|
|
||||||
|
&>view { |
||||||
|
flex: 1; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// 头部统计 |
||||||
|
.title { |
||||||
|
display: flex; |
||||||
|
justify-content: space-around; |
||||||
|
font-size: 32upx; |
||||||
|
// font-weight: bold; |
||||||
|
margin: 10upx 0; |
||||||
|
|
||||||
|
&>view { |
||||||
|
padding: 15upx 0; |
||||||
|
flex: 1; |
||||||
|
text-align: center; |
||||||
|
position: relative; |
||||||
|
// background: #fff; |
||||||
|
transition: all 0.3s; |
||||||
|
border-radius: 10upx; |
||||||
|
|
||||||
|
// &::after { |
||||||
|
// content: ''; |
||||||
|
// display: block; |
||||||
|
// position: absolute; |
||||||
|
// height: 4upx; |
||||||
|
// width: 0; |
||||||
|
// // background: var(--subjectColor); |
||||||
|
// top: 100%; |
||||||
|
// left: 50%; |
||||||
|
// transition: all 0.5s; |
||||||
|
// } |
||||||
|
|
||||||
|
&.active { |
||||||
|
background: var(--subjectColor); |
||||||
|
color: #fff; |
||||||
|
|
||||||
|
&::after { |
||||||
|
width: 100%; |
||||||
|
left: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.title__number { |
||||||
|
color: var(--subjectColor); |
||||||
|
} |
||||||
|
|
||||||
|
// 批量操作按钮 |
||||||
|
.batchOperationBtn { |
||||||
|
border: 1upx solid var(--subjectColor); |
||||||
|
text-align: center; |
||||||
|
padding: 10upx 0; |
||||||
|
color: var(--subjectColor); |
||||||
|
border-radius: 10upx; |
||||||
|
width: 200upx; |
||||||
|
font-size: 28upx; |
||||||
|
margin: 0; |
||||||
|
margin-right: 10upx; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// 控件 |
||||||
|
.control { |
||||||
|
background: #fff; |
||||||
|
padding: 10upx 0; |
||||||
|
} |
||||||
|
|
||||||
|
.uni-table-scroll { |
||||||
|
zoom: 0.9; |
||||||
|
} |
||||||
|
|
||||||
|
.uni-table-td, |
||||||
|
.uni-table-th { |
||||||
|
--borderColor: var(--subjectColor); |
||||||
|
color: var(--borderColor); |
||||||
|
padding: 10upx; |
||||||
|
|
||||||
|
font-size: 28upx; |
||||||
|
} |
||||||
|
|
||||||
|
.table--border { |
||||||
|
--borderColor: var(--subjectColor); |
||||||
|
border-color: var(--borderColor); |
||||||
|
} |
||||||
|
|
||||||
|
:deep(.checkbox.tr-table--border) { |
||||||
|
--borderColor: var(--subjectColor); |
||||||
|
border-color: var(--borderColor); |
||||||
|
|
||||||
|
.checkbox__inner { |
||||||
|
border-color: var(--borderColor); |
||||||
|
} |
||||||
|
} |
||||||
|
</style> |
@ -0,0 +1,648 @@ |
|||||||
|
<template> |
||||||
|
<!-- 顶部导航栏 --> |
||||||
|
<u-navbar title="库位查询" placeholder :autoBack="true" leftIconSize='35' bgColor='#d3832a' leftIconColor='#ffffff' |
||||||
|
titleStyle='color:#ffffff'></u-navbar> |
||||||
|
|
||||||
|
<view class="container"> |
||||||
|
<!-- 顶部搜索栏 --> |
||||||
|
<view class="header-search"> |
||||||
|
<view class="search"> |
||||||
|
<input class="searchInput" v-model="scancode" type="text"> |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class="search"> |
||||||
|
<view class="searchType" @click="scandata"> |
||||||
|
搜索 |
||||||
|
</view> |
||||||
|
|
||||||
|
</view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class="orderInfo"> |
||||||
|
<!-- 库位数据 --> |
||||||
|
<view class="orderInfo_title"> |
||||||
|
<view class="orderInfo_title_row"> |
||||||
|
<view class=""> |
||||||
|
<view class="row_title1"> |
||||||
|
托盘名称: |
||||||
|
</view> |
||||||
|
<view> |
||||||
|
{{info.trayInfo.palletName || '暂无数据'}} |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class=""> |
||||||
|
<view class="row_title2"> |
||||||
|
托盘码: |
||||||
|
</view> |
||||||
|
<view class=""> |
||||||
|
{{info.trayInfo.palletCode || '暂无数据'}} |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class="orderInfo_title_row"> |
||||||
|
<view class=""> |
||||||
|
<text class="row_title1"> |
||||||
|
打托方式: |
||||||
|
</text> |
||||||
|
{{info.trayType || '暂无数据'}} |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class=""> |
||||||
|
<text class=""> |
||||||
|
商场: |
||||||
|
</text> |
||||||
|
{{info.marketName || '暂无数据'}} |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class="orderInfo_title_row"> |
||||||
|
<view class=""> |
||||||
|
<text class="row_title1"> |
||||||
|
包件数: |
||||||
|
</text> |
||||||
|
{{info.totalNum || 0}} |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class=""> |
||||||
|
<text class="row_title2"> |
||||||
|
订单包件总数: |
||||||
|
</text> |
||||||
|
{{info.orderTotalNum || 0}} |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class="orderInfo_title_row"> |
||||||
|
<view class=""> |
||||||
|
<text class="row_title1"> |
||||||
|
库存品数: |
||||||
|
</text> |
||||||
|
{{info.stockNum || 0}} |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class=""> |
||||||
|
<text class="row_title2"> |
||||||
|
库存品订单总数: |
||||||
|
</text> |
||||||
|
{{info.stockTotalNum || 0}} |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<view class="title"> |
||||||
|
<view @click="handleTabBarState(1)" :class="{'active': tabBarCode === 1}"> |
||||||
|
定制品 |
||||||
|
</view> |
||||||
|
<view @click="handleTabBarState(2)" :class="{'active': tabBarCode === 2}"> |
||||||
|
零担 |
||||||
|
</view> |
||||||
|
<view @click="handleTabBarState(3)" :class="{'active': tabBarCode === 3}"> |
||||||
|
库存品 |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<!-- 定制品 --> |
||||||
|
<view class="packagesList" v-if="tabBarCode === 1"> |
||||||
|
<!-- 控件 --> |
||||||
|
<view class="control"> |
||||||
|
<view v-if="!isBatchOperation"> |
||||||
|
<view class="batchOperationBtn" @click="isBatchOperation = true">批量操作</view> |
||||||
|
</view> |
||||||
|
<view v-else style="display: flex;"> |
||||||
|
<view class="batchOperationBtn" @click="batchPrint">打印</view> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<scroll-view scroll-y="true" style="height: 60vh; margin-top: 10px;"> |
||||||
|
<uni-table type="selection" border stripe emptyText="暂无更多数据" |
||||||
|
@selection-change="({detail: {index}})=> selectionChange(index, 'order')"> |
||||||
|
<!-- 表头行 --> |
||||||
|
<uni-tr> |
||||||
|
<uni-th align="left">包条码</uni-th> |
||||||
|
<uni-th align="left">合同号</uni-th> |
||||||
|
<uni-th align="left">运单号</uni-th> |
||||||
|
<uni-th align="left">仓库</uni-th> |
||||||
|
<uni-th align="left">数量</uni-th> |
||||||
|
</uni-tr> |
||||||
|
<!-- 表格数据行 --> |
||||||
|
<block v-for="item in packageList"> |
||||||
|
<uni-tr> |
||||||
|
<!-- 包条码 --> |
||||||
|
<uni-td>{{item.orderPackageCode}}</uni-td> |
||||||
|
<!-- 合同号 --> |
||||||
|
<uni-td>{{item.orderCode}}</uni-td> |
||||||
|
<!-- 运单号 --> |
||||||
|
<uni-td>{{item.waybillNo}}</uni-td> |
||||||
|
<!-- 仓库 --> |
||||||
|
<uni-td>{{item.warehouseName}}</uni-td> |
||||||
|
<!-- 数量 --> |
||||||
|
<uni-td>{{item.num}}</uni-td> |
||||||
|
</uni-tr> |
||||||
|
</block> |
||||||
|
|
||||||
|
</uni-table> |
||||||
|
</scroll-view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<!-- 零担 --> |
||||||
|
<view class="packagesList" v-else-if="tabBarCode === 2"> |
||||||
|
<scroll-view scroll-y="true" style="height: 60vh; margin-top: 10px;"> |
||||||
|
<uni-table type="selection" border stripe emptyText="暂无更多数据" |
||||||
|
@selection-change="({detail: {index}})=>selectionChange(index, 'zero')"> |
||||||
|
<!-- 表头行 --> |
||||||
|
<uni-tr> |
||||||
|
<uni-th align="left">运单号</uni-th> |
||||||
|
<uni-th align="left">合同号</uni-th> |
||||||
|
<uni-th align="left">仓库</uni-th> |
||||||
|
<uni-th align="center">数量</uni-th> |
||||||
|
</uni-tr> |
||||||
|
<!-- 表格数据行 --> |
||||||
|
<block v-for="item in zeroList"> |
||||||
|
<uni-tr> |
||||||
|
<!-- 运单号 --> |
||||||
|
<uni-td>{{item.waybillNo}}</uni-td> |
||||||
|
<!-- 合同号 --> |
||||||
|
<uni-td>{{item.orderCode}}</uni-td> |
||||||
|
<!-- 仓库 --> |
||||||
|
<uni-td>{{item.warehouseName}}</uni-td> |
||||||
|
<!-- 数量 --> |
||||||
|
<uni-td align="center">{{item.num}}</uni-td> |
||||||
|
</uni-tr> |
||||||
|
</block> |
||||||
|
</uni-table> |
||||||
|
</scroll-view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<!-- 库存品 --> |
||||||
|
<view class="packagesList" v-else-if="tabBarCode === 3"> |
||||||
|
<scroll-view scroll-y="true" style="height: 60vh; margin-top: 10px;"> |
||||||
|
<uni-table type="selection" border stripe emptyText="暂无更多数据" |
||||||
|
@selection-change="({detail: {index}})=>selectionChange(index, 'stock')"> |
||||||
|
<!-- 表头行 --> |
||||||
|
<uni-tr> |
||||||
|
<uni-th align="left">批次号</uni-th> |
||||||
|
<uni-th align="left">物料编码</uni-th> |
||||||
|
<uni-th align="left">物料名称</uni-th> |
||||||
|
<uni-th align="left">商场名称</uni-th> |
||||||
|
<uni-th align="center">仓库</uni-th> |
||||||
|
<uni-th align="center">在库数</uni-th> |
||||||
|
</uni-tr> |
||||||
|
<!-- 表格数据行 --> |
||||||
|
<block v-for="item in stockList"> |
||||||
|
<uni-tr> |
||||||
|
<!-- 批次号 --> |
||||||
|
<uni-td>{{item.incomingBatch}}</uni-td> |
||||||
|
<!-- 物料编码 --> |
||||||
|
<uni-td>{{item.materialCode}}</uni-td> |
||||||
|
<!-- 物料名称 --> |
||||||
|
<uni-td>{{item.materialName}}</uni-td> |
||||||
|
<!-- 商场名称 --> |
||||||
|
<uni-td>{{item.marketName}}</uni-td> |
||||||
|
<!-- 仓库 --> |
||||||
|
<uni-td>{{item.warehouseName}}</uni-td> |
||||||
|
<!-- 数量 --> |
||||||
|
<uni-td align="center">{{item.num}}</uni-td> |
||||||
|
</uni-tr> |
||||||
|
</block> |
||||||
|
</uni-table> |
||||||
|
</scroll-view> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
<tiplist ref="tiplists"></tiplist> |
||||||
|
<!-- #ifdef APP --> |
||||||
|
<saomiao2 :ishidestop="scanState !== 0"></saomiao2> |
||||||
|
<!-- #endif --> |
||||||
|
<BluetoothList ref="bluetoothList"></BluetoothList> |
||||||
|
</template> |
||||||
|
|
||||||
|
<script lang="ts" setup> |
||||||
|
import { ref, reactive, shallowRef, watch, nextTick, computed } from 'vue'; |
||||||
|
import { |
||||||
|
onShow, |
||||||
|
onHide, |
||||||
|
onLoad, |
||||||
|
onReachBottom, |
||||||
|
onPullDownRefresh |
||||||
|
} from '@dcloudio/uni-app' |
||||||
|
import utils from '@/utils/utils.js'; |
||||||
|
import { |
||||||
|
postFindTrayData, |
||||||
|
BatchPrintPackages |
||||||
|
} from '@/api/user.js' |
||||||
|
import useBluetoothStore from '@/store/useBluetoothStore.js'; |
||||||
|
import useSystemSettingsStore from '@/store/useSystemSettingsStore'; |
||||||
|
import { storeToRefs } from 'pinia'; |
||||||
|
const { scanState } = storeToRefs(useSystemSettingsStore()) |
||||||
|
const bluetoothList = ref(null) |
||||||
|
const bluetoothStore = useBluetoothStore() |
||||||
|
const { bluetoothInfo } = storeToRefs(bluetoothStore) |
||||||
|
|
||||||
|
// 订单详情 |
||||||
|
const dataInfo = shallowRef<any>({}) |
||||||
|
|
||||||
|
/** 是否开启批量操作 */ |
||||||
|
const isBatchOperation = ref<Boolean>(false) |
||||||
|
|
||||||
|
/** 是否显示定制品 */ |
||||||
|
const showArticleMadeToOrder = ref<Boolean>(true) |
||||||
|
|
||||||
|
/** 扫码码值 */ |
||||||
|
const scancode = ref<string>('') |
||||||
|
|
||||||
|
/** 包件列表 */ |
||||||
|
const packageList = shallowRef([]) |
||||||
|
|
||||||
|
/** 零担列表 */ |
||||||
|
const zeroList = shallowRef([]) |
||||||
|
|
||||||
|
/** 库存品列表 */ |
||||||
|
const stockList = shallowRef([]) |
||||||
|
|
||||||
|
/** 详情 */ |
||||||
|
const info = ref<any>({ trayInfo: {} }) |
||||||
|
|
||||||
|
// 订单状态字典 |
||||||
|
const orderStateDictionaries = reactive({ |
||||||
|
'10': '部分入库', |
||||||
|
'20': '已入库', |
||||||
|
'30': '部分出库', |
||||||
|
'40': '已出库', |
||||||
|
'50': '部分装车', |
||||||
|
'60': '已装车', |
||||||
|
'70': '部分签收', |
||||||
|
'80': '已签收', |
||||||
|
}) |
||||||
|
|
||||||
|
/** tabBar 激活 */ |
||||||
|
const tabBarCode = ref(1) |
||||||
|
|
||||||
|
/** 修改物料表单 */ |
||||||
|
const form = ref({}) |
||||||
|
|
||||||
|
/** 复选框选中的数据 */ |
||||||
|
const selectionList = ref([]) |
||||||
|
|
||||||
|
// 组件实例 |
||||||
|
const tiplists = ref(null) |
||||||
|
|
||||||
|
|
||||||
|
onLoad(() => { |
||||||
|
// #ifdef APP |
||||||
|
utils.ttsspke('库位查询, 请扫描或输入库位码') |
||||||
|
// #endif |
||||||
|
}) |
||||||
|
|
||||||
|
// 开启监听扫描 |
||||||
|
onShow(async () => { |
||||||
|
// #ifdef APP |
||||||
|
uni.$off('scancodedate') |
||||||
|
uni.$on('scancodedate', function (code) { |
||||||
|
if (code) { |
||||||
|
scancode.value = code |
||||||
|
|
||||||
|
scandata() |
||||||
|
} |
||||||
|
}) |
||||||
|
// #endif |
||||||
|
}) |
||||||
|
|
||||||
|
onPullDownRefresh(() => { |
||||||
|
const timer = setTimeout(() => { |
||||||
|
dataInfo.value = {} |
||||||
|
scancode.value = '' |
||||||
|
packageList.value = [] |
||||||
|
|
||||||
|
uni.stopPullDownRefresh() |
||||||
|
clearTimeout(timer) |
||||||
|
}, 300) |
||||||
|
}) |
||||||
|
|
||||||
|
async function scandata() { |
||||||
|
const res = await postFindTrayData({ trayCode: scancode.value }) |
||||||
|
console.log('res :>> ', res); |
||||||
|
const { code, data } = res |
||||||
|
|
||||||
|
if (code !== 200 || !data) return |
||||||
|
|
||||||
|
// 库位信息 |
||||||
|
info.value = data.trayTyprInfo || {} |
||||||
|
|
||||||
|
// 库位托盘信息 |
||||||
|
info.value.trayInfo = data.trayEntity || {} |
||||||
|
|
||||||
|
// 定制品 |
||||||
|
packageList.value = data.packageList |
||||||
|
|
||||||
|
// 零担 |
||||||
|
zeroList.value = data.zeroOrderList |
||||||
|
|
||||||
|
// 库存品 |
||||||
|
stockList.value = data.stockOrderList |
||||||
|
} |
||||||
|
|
||||||
|
/** 设置tabBar激活状态 */ |
||||||
|
const handleTabBarState = (code) => { |
||||||
|
selectionList.value = [] |
||||||
|
tabBarCode.value = code |
||||||
|
} |
||||||
|
|
||||||
|
/** 复选框改变时 */ |
||||||
|
const selectionChange = (list : [], type : string) => { |
||||||
|
console.log('list :>> ', list); |
||||||
|
selectionList.value = list |
||||||
|
} |
||||||
|
|
||||||
|
/** 打印 */ |
||||||
|
const batchPrint = async () => { |
||||||
|
if (selectionList.value.length === 0) return uni.showToast({ |
||||||
|
title: '最少选择一条数据', |
||||||
|
icon: 'none' |
||||||
|
}) |
||||||
|
|
||||||
|
const _idsArr = [] |
||||||
|
|
||||||
|
for (let i = 0; i < selectionList.value.length; i++) { |
||||||
|
// selectionList内存储的是被选中的索引 |
||||||
|
const index = selectionList.value[i] |
||||||
|
_idsArr.push(packageList.value[index].packageId) |
||||||
|
} |
||||||
|
|
||||||
|
const idsValue = _idsArr.join(',') |
||||||
|
|
||||||
|
const res = await BatchPrintPackages(idsValue) |
||||||
|
const { code, data } = res |
||||||
|
if (code !== 200) return |
||||||
|
console.log('res :>> ', res); |
||||||
|
tiplists.value.setdetails({ |
||||||
|
title: '请选择需要打印的包条码', |
||||||
|
isshow: true, |
||||||
|
tipstate: 2, |
||||||
|
list: [], |
||||||
|
inputtext: '', |
||||||
|
confirmTxt: '确认选择', |
||||||
|
isonecheck: true, |
||||||
|
success: () => { |
||||||
|
// if (deta.checklist.length == 0) { |
||||||
|
// uni.showToast({ |
||||||
|
// title: '请选择包条码', |
||||||
|
// icon: 'none' |
||||||
|
// }) |
||||||
|
// return |
||||||
|
// } |
||||||
|
console.log('data :>> ', data); |
||||||
|
// #ifdef APP |
||||||
|
if (!bluetoothInfo.value.name) return bluetoothList.value.setdetails({ isshow: true }) |
||||||
|
let _isReturn = false |
||||||
|
data.map(item => { |
||||||
|
if (_isReturn) return |
||||||
|
let text = '! 0 200 200 330 1\r\n' |
||||||
|
text += 'SETBOLD 1\r\n' |
||||||
|
text += `T 56 0 0 0 ${item.orderCode}\r\n` |
||||||
|
text += 'LINE 0 50 420 50 3\r\n' |
||||||
|
text += `T 55 0 0 60 客户\r\n` |
||||||
|
text += 'LINE 40 50 40 110 3\r\n' |
||||||
|
text += `T 55 0 50 60 ${item.customerName}\r\n` |
||||||
|
text += 'LINE 40 80 420 80 3\r\n' |
||||||
|
text += `T 55 0 50 90 ${item.customerAddress}\r\n` |
||||||
|
text += 'LINE 0 110 420 110 3\r\n' |
||||||
|
text += `T 55 0 0 120 物料\r\n` |
||||||
|
text += 'LINE 40 110 40 140 3\r\n' |
||||||
|
text += `T 55 0 50 120 ${item.materialName || item.category}\r\n` |
||||||
|
text += 'LINE 0 140 420 140 3\r\n' |
||||||
|
text += 'B QR 150 150 M 2 U 4\r\n' |
||||||
|
text += `MA,${item.qrCode}\r\n` |
||||||
|
text += 'ENDQR\r\n' |
||||||
|
text += `T 55 0 140 260 ${item.qrCode}\r\n` |
||||||
|
text += 'FORM\r\n' |
||||||
|
text += 'PRINT\r\n' |
||||||
|
utils.getbl(bluetoothInfo.value, text).catch(() => { |
||||||
|
bluetoothList.value.setdetails({ isshow: true }) |
||||||
|
_isReturn = true |
||||||
|
}) |
||||||
|
}) |
||||||
|
if (_isReturn) return |
||||||
|
// #endif |
||||||
|
tiplists.value.setdetails({ isshow: false }) |
||||||
|
}, |
||||||
|
cancel: (details) => { |
||||||
|
tiplists.value.setdetails({ isshow: false }) |
||||||
|
}, |
||||||
|
close: (details) => { |
||||||
|
tiplists.value.setdetails({ isshow: false }) |
||||||
|
} |
||||||
|
}) |
||||||
|
} |
||||||
|
</script> |
||||||
|
|
||||||
|
<style lang="scss" scoped> |
||||||
|
.w100 { |
||||||
|
width: 100%; |
||||||
|
} |
||||||
|
|
||||||
|
// 最外层容器 |
||||||
|
.container { |
||||||
|
padding: 20upx; |
||||||
|
font-size: 28upx; // 本页字体大小 |
||||||
|
} |
||||||
|
|
||||||
|
// 顶部搜索栏 |
||||||
|
.header-search { |
||||||
|
height: 60upx; |
||||||
|
padding: 0 0 20upx; |
||||||
|
// border-bottom: 1upx solid #aaa; |
||||||
|
display: flex; |
||||||
|
justify-content: space-between; |
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
.search { |
||||||
|
position: relative; |
||||||
|
|
||||||
|
// 查询结果的列表 |
||||||
|
.searchResultList { |
||||||
|
position: absolute; |
||||||
|
top: 120%; |
||||||
|
width: 100%; |
||||||
|
background: #fff; |
||||||
|
z-index: 80; |
||||||
|
text-align: center; |
||||||
|
line-height: 60upx; |
||||||
|
max-height: 300upx; |
||||||
|
overflow-y: scroll; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// 搜索输入框 |
||||||
|
.searchInput { |
||||||
|
background: #fff; |
||||||
|
width: 500upx; |
||||||
|
height: 100%; |
||||||
|
padding-left: 20upx; |
||||||
|
border: 1upx solid var(--subjectColor); |
||||||
|
border-radius: 30upx; |
||||||
|
} |
||||||
|
|
||||||
|
// 搜索类型 |
||||||
|
.searchType { |
||||||
|
height: 100%; |
||||||
|
display: flex; |
||||||
|
align-items: center; |
||||||
|
padding: 0 40upx; |
||||||
|
background: #fff; |
||||||
|
border: 1upx solid var(--subjectColor); |
||||||
|
border-radius: 10upx; |
||||||
|
color: var(--subjectColor); |
||||||
|
} |
||||||
|
|
||||||
|
// 数据详情 |
||||||
|
.dataInfo { |
||||||
|
display: flex; |
||||||
|
flex-wrap: wrap; |
||||||
|
// border-bottom: 1upx solid #aaa; |
||||||
|
background: #fff; |
||||||
|
} |
||||||
|
|
||||||
|
.dataInfo__item { |
||||||
|
flex: none; |
||||||
|
min-width: 50%; |
||||||
|
max-width: 100%; |
||||||
|
line-height: 60upx; |
||||||
|
display: inline-flex; |
||||||
|
|
||||||
|
.label { |
||||||
|
display: inline-block; |
||||||
|
width: 160upx; |
||||||
|
text-align: right; |
||||||
|
margin-right: 20rpx; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// 订单列表信息 |
||||||
|
.orderInfo { |
||||||
|
// background: #fff; |
||||||
|
margin-top: 10upx; |
||||||
|
|
||||||
|
.orderInfo_title { |
||||||
|
background: #fff; |
||||||
|
font-size: 32upx; |
||||||
|
padding: 15upx; |
||||||
|
border-radius: 5upx; |
||||||
|
box-sizing: border-box; |
||||||
|
box-shadow: 0 0 10px #acc, 3px 3px #abb; |
||||||
|
font-size: 28upx; |
||||||
|
|
||||||
|
.row_title1 { |
||||||
|
display: inline-block; |
||||||
|
min-width: 140upx; |
||||||
|
} |
||||||
|
|
||||||
|
.row_title2 { |
||||||
|
display: inline-block; |
||||||
|
min-width: 200upx; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
.orderInfo_title_row { |
||||||
|
display: flex; |
||||||
|
margin-top: 10upx; |
||||||
|
|
||||||
|
&>view { |
||||||
|
flex: 1; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// 头部统计 |
||||||
|
.title { |
||||||
|
display: flex; |
||||||
|
justify-content: space-around; |
||||||
|
font-size: 32upx; |
||||||
|
// font-weight: bold; |
||||||
|
margin: 10upx 0; |
||||||
|
|
||||||
|
&>view { |
||||||
|
padding: 15upx 0; |
||||||
|
flex: 1; |
||||||
|
text-align: center; |
||||||
|
position: relative; |
||||||
|
// background: #fff; |
||||||
|
transition: all 0.3s; |
||||||
|
border-radius: 10upx; |
||||||
|
|
||||||
|
// &::after { |
||||||
|
// content: ''; |
||||||
|
// display: block; |
||||||
|
// position: absolute; |
||||||
|
// height: 4upx; |
||||||
|
// width: 0; |
||||||
|
// // background: var(--subjectColor); |
||||||
|
// top: 100%; |
||||||
|
// left: 50%; |
||||||
|
// transition: all 0.5s; |
||||||
|
// } |
||||||
|
|
||||||
|
&.active { |
||||||
|
background: var(--subjectColor); |
||||||
|
color: #fff; |
||||||
|
|
||||||
|
&::after { |
||||||
|
width: 100%; |
||||||
|
left: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.title__number { |
||||||
|
color: var(--subjectColor); |
||||||
|
} |
||||||
|
|
||||||
|
// 批量操作按钮 |
||||||
|
.batchOperationBtn { |
||||||
|
border: 1upx solid var(--subjectColor); |
||||||
|
text-align: center; |
||||||
|
padding: 10upx 0; |
||||||
|
color: var(--subjectColor); |
||||||
|
border-radius: 10upx; |
||||||
|
width: 200upx; |
||||||
|
font-size: 28upx; |
||||||
|
margin: 0; |
||||||
|
margin-right: 10upx; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// 控件 |
||||||
|
.control { |
||||||
|
background: #fff; |
||||||
|
padding: 10upx 0; |
||||||
|
} |
||||||
|
|
||||||
|
.uni-table-scroll { |
||||||
|
zoom: 0.9; |
||||||
|
} |
||||||
|
|
||||||
|
.uni-table-td, |
||||||
|
.uni-table-th { |
||||||
|
--borderColor: var(--subjectColor); |
||||||
|
color: var(--borderColor); |
||||||
|
padding: 10upx; |
||||||
|
|
||||||
|
font-size: 28upx; |
||||||
|
} |
||||||
|
|
||||||
|
.table--border { |
||||||
|
--borderColor: var(--subjectColor); |
||||||
|
border-color: var(--borderColor); |
||||||
|
} |
||||||
|
|
||||||
|
:deep(.checkbox.tr-table--border) { |
||||||
|
--borderColor: var(--subjectColor); |
||||||
|
border-color: var(--borderColor); |
||||||
|
|
||||||
|
.checkbox__inner { |
||||||
|
border-color: var(--borderColor); |
||||||
|
} |
||||||
|
} |
||||||
|
</style> |
File diff suppressed because one or more lines are too long
File diff suppressed because it is too large
Load Diff
@ -1 +1 @@ |
|||||||
<view class="titles">个人中心</view><image class="usebg" src="/static/userbg.png"></image><view wx:if="{{a}}" class="userviews" bindtap="{{b}}"><image src="/static/userimg.png"></image><view><view>未登录</view></view></view><view wx:if="{{c}}" class="userviews"><image src="/static/userimg.png"></image><view><view>{{d}}</view><view><view></view><view bindtap="{{g}}"><view>{{e}}-{{f}}</view><image src="/static/rigthviewb.png"></image></view></view></view></view><view class="btsview"><view wx:for="{{h}}" wx:for-item="item" bindtap="{{item.c}}"><view><image src="{{item.a}}"></image><view>{{item.b}}</view></view><view><image src="/static/rigthview.png"></image></view></view></view><view class="butout" bindtap="{{i}}"> 退出登录 </view><view wx:if="{{j}}" class="bgmabx" bindtap="{{n}}"><view class="changkus" catchtap="{{m}}"><view class="tis"><image class="bgimgs" src="/static/tpbg.png"></image><image class="ckbgcc" src="/static/changku.png"></image><view class="titlck">选择仓库</view><scroll-view scroll-y="true" class="scvuew"><view class="maboxs"><view wx:for="{{k}}" wx:for-item="item" bindtap="{{item.b}}" class="{{item.c}}">{{item.a}}</view></view></scroll-view><view class="submitcheck" bindtap="{{l}}">确认选择</view></view></view></view><view class="zhanwei"></view><tiplist class="r" u-r="tiplists" u-i="4ed4f5f0-0" bind:__l="__l"></tiplist><tips class="r" u-r="tip" u-i="4ed4f5f0-1" bind:__l="__l"></tips> |
<view class="titles">个人中心</view><image class="usebg" src="/static/userbg.png"></image><view wx:if="{{a}}" class="userviews" bindtap="{{b}}"><image class="profilePhoto" src="/static/appIcon/favicon.png"></image><view><view>未登录</view></view></view><view wx:if="{{c}}" class="userviews"><image class="profilePhoto" src="/static/appIcon/favicon.png"></image><view><view>{{d}}</view><view><view></view><view bindtap="{{g}}"><view>{{e}}-{{f}}</view><image src="/static/rigthviewb.png"></image></view></view></view></view><view class="btsview"><view wx:for="{{h}}" wx:for-item="item" bindtap="{{item.c}}"><view><image src="{{item.a}}"></image><view>{{item.b}}</view></view><view><image src="/static/rigthview.png"></image></view></view></view><view class="butout" bindtap="{{i}}"> 退出登录 </view><view wx:if="{{j}}" class="bgmabx" bindtap="{{n}}"><view class="changkus" catchtap="{{m}}"><view class="tis"><image class="bgimgs" src="/static/tpbg.png"></image><image class="ckbgcc" src="/static/changku.png"></image><view class="titlck">选择仓库</view><scroll-view scroll-y="true" class="scvuew"><view class="maboxs"><view wx:for="{{k}}" wx:for-item="item" bindtap="{{item.b}}" class="{{item.c}}">{{item.a}}</view></view></scroll-view><view class="submitcheck" bindtap="{{l}}">确认选择</view></view></view></view><view class="zhanwei"></view><tiplist class="r" u-r="tiplists" u-i="4ed4f5f0-0" bind:__l="__l"></tiplist><tips class="r" u-r="tip" u-i="4ed4f5f0-1" bind:__l="__l"></tips> |
File diff suppressed because one or more lines are too long
@ -1 +1 @@ |
|||||||
<u-navbar wx:if="{{a}}" u-i="1f112ba4-0" bind:__l="__l" u-p="{{a}}"></u-navbar><view class="hedtopt"><view class="typto"><view>配车类型:{{b}}</view><view>配车状态:{{c}}</view></view><view class="typto"><view>车牌号:{{d}}</view><view>司机:{{e}}</view></view><view class="typto"><view>装卸班组:{{f}}</view><view>备货是否完成:{{g}}</view></view><view class="kehupeison"><view><view>配送客户数</view><view>{{h}}</view></view><view><view>订单总数</view><view>{{i}}</view></view><view><view>计划件数</view><view>{{j}}</view></view><view><view>装车数量</view><view>{{k}}</view></view><view><view>签收件数</view><view>{{l}}</view></view></view></view><scroll-view scroll-y="true" class="scvbx"><view class="mabx"><view wx:for="{{m}}" wx:for-item="item" class="its"><view class="title"><view style="{{item.c}}">客户:{{item.a}} {{item.b}}</view><view class="statetype">{{item.d}}</view></view><view class="conxb"><view><view>订单总数</view><view>{{item.e}}</view></view><view><view>配送件数</view><view>{{item.f}}</view></view><view><view>扫描件数</view><view>{{item.g}}</view></view></view><view class="info"><view class=""> 客户电话: {{item.h}}</view><view class=""> 客户地址: {{item.i}}</view></view><view class="remarks"> 备注:{{item.j}}</view><view class="tbck"><view class="buts"><view class="{{item.l}}" bindtap="{{item.m}}">{{item.k}}</view><view bindtap="{{item.n}}">签收扫描</view><view bindtap="{{item.o}}">上传签收图片</view></view><view bindtap="{{item.p}}" class="mabut"> 设置增值服务 </view><view wx:if="{{item.q}}" class="mabut" bindtap="{{item.r}}"> 批量签收 </view></view></view></view></scroll-view><tiplist class="r" u-r="tiplists" u-i="1f112ba4-1" bind:__l="__l"></tiplist> |
<u-navbar wx:if="{{a}}" u-i="1f112ba4-0" bind:__l="__l" u-p="{{a}}"></u-navbar><view class="hedtopt"><view class="typto"><view>配车类型:{{b}}</view><view>配车状态:{{c}}</view></view><view class="typto"><view>车牌号:{{d}}</view><view>司机:{{e}}</view></view><view class="typto"><view>装卸班组:{{f}}</view><view>备货是否完成:{{g}}</view></view><view class="kehupeison"><view><view>配送客户数</view><view>{{h}}</view></view><view><view>订单总数</view><view>{{i}}</view></view><view><view>计划件数</view><view>{{j}}</view></view><view><view>装车数量</view><view>{{k}}</view></view><view><view>签收件数</view><view>{{l}}</view></view></view></view><scroll-view scroll-y="true" class="scvbx"><view class="mabx"><view wx:for="{{m}}" wx:for-item="item" class="its"><view class="title"><view style="{{item.c}}">客户:{{item.a}} {{item.b}}</view><view class="statetype">{{item.d}}</view></view><view class="conxb"><view><view>订单总数</view><view>{{item.e}}</view></view><view><view>计划件数</view><view>{{item.f}}</view></view><view><view>扫描件数</view><view>{{item.g}}</view></view></view><view class="info"><view class=""> 客户电话: {{item.h}}</view><view class=""> 客户地址: {{item.i}}</view></view><view class="remarks"> 备注:{{item.j}}</view><view class="tbck"><view class="buts"><view class="{{item.l}}" bindtap="{{item.m}}">{{item.k}}</view><view bindtap="{{item.n}}">签收扫描</view><view bindtap="{{item.o}}">上传签收图片</view></view><view bindtap="{{item.p}}" class="mabut"> 设置增值服务 </view><view wx:if="{{item.q}}" class="mabut" bindtap="{{item.r}}"> 批量签收 </view></view></view></view></scroll-view><tiplist class="r" u-r="tiplists" u-i="1f112ba4-1" bind:__l="__l"></tiplist> |
File diff suppressed because one or more lines are too long
Loading…
Reference in new issue