添加web的合卷分卷合并操作
This commit is contained in:
77
apps/hand-factory/api/wms/pendingAction.js
Normal file
77
apps/hand-factory/api/wms/pendingAction.js
Normal file
@@ -0,0 +1,77 @@
|
||||
import request from '@/utils/request'
|
||||
|
||||
// 查询钢卷待操作列表
|
||||
export function listPendingAction(query) {
|
||||
return request({
|
||||
url: '/wms/coilPendingAction/list',
|
||||
method: 'get',
|
||||
params: query
|
||||
})
|
||||
}
|
||||
|
||||
// 查询钢卷待操作详细
|
||||
export function getPendingAction(actionId) {
|
||||
return request({
|
||||
url: '/wms/coilPendingAction/' + actionId,
|
||||
method: 'get'
|
||||
})
|
||||
}
|
||||
|
||||
// 新增钢卷待操作
|
||||
export function addPendingAction(data) {
|
||||
return request({
|
||||
url: '/wms/coilPendingAction',
|
||||
method: 'post',
|
||||
data: data
|
||||
})
|
||||
}
|
||||
|
||||
// 修改钢卷待操作
|
||||
export function updatePendingAction(data) {
|
||||
return request({
|
||||
url: '/wms/coilPendingAction',
|
||||
method: 'put',
|
||||
data: data
|
||||
})
|
||||
}
|
||||
|
||||
// 删除钢卷待操作
|
||||
export function delPendingAction(actionId) {
|
||||
return request({
|
||||
url: '/wms/coilPendingAction/' + actionId,
|
||||
method: 'delete'
|
||||
})
|
||||
}
|
||||
|
||||
// 更新操作状态
|
||||
export function updateStatus(actionId, status) {
|
||||
return request({
|
||||
url: `/wms/coilPendingAction/status/${actionId}/${status}`,
|
||||
method: 'put'
|
||||
})
|
||||
}
|
||||
|
||||
// 开始处理操作
|
||||
export function startProcess(actionId) {
|
||||
return request({
|
||||
url: `/wms/coilPendingAction/start/${actionId}`,
|
||||
method: 'put'
|
||||
})
|
||||
}
|
||||
|
||||
// 完成操作
|
||||
export function completeAction(actionId) {
|
||||
return request({
|
||||
url: `/wms/coilPendingAction/complete/${actionId}`,
|
||||
method: 'put'
|
||||
})
|
||||
}
|
||||
|
||||
// 取消操作
|
||||
export function cancelAction(actionId) {
|
||||
return request({
|
||||
url: `/wms/coilPendingAction/cancel/${actionId}`,
|
||||
method: 'put'
|
||||
})
|
||||
}
|
||||
|
||||
@@ -17,7 +17,7 @@
|
||||
<!-- 刷新按钮 -->
|
||||
<view class="refresh-btn-fixed" @click="refreshData">
|
||||
<text class="refresh-icon" :class="{ 'rotating': isRefreshing }">⟳</text>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<scroll-view scroll-y class="scroll-container" v-if="currentTab === 1">
|
||||
<!-- 顶部状态栏 -->
|
||||
@@ -25,12 +25,12 @@
|
||||
<view class="status-item">
|
||||
<text class="status-label">网络状态</text>
|
||||
<text class="status-value" :class="'status-' + webStatus[0].value">{{ webStatus[0].value }}</text>
|
||||
</view>
|
||||
</view>
|
||||
<view class="status-divider"></view>
|
||||
<view class="status-item">
|
||||
<text class="status-label">当前班组</text>
|
||||
<text class="status-value">{{ webStatus[1].value }}</text>
|
||||
</view>
|
||||
</view>
|
||||
<view class="status-divider"></view>
|
||||
<view class="status-item">
|
||||
<text class="status-label">更新时间</text>
|
||||
@@ -46,9 +46,9 @@
|
||||
<text class="metric-name">{{ item.label }}</text>
|
||||
<text class="metric-value">{{ item.value }}</text>
|
||||
<text class="metric-unit">{{ item.unit }}</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<!-- 机架压下率 -->
|
||||
<view class="section">
|
||||
@@ -58,17 +58,17 @@
|
||||
<text class="metric-name">{{ item.label }}</text>
|
||||
<text class="metric-value">{{ item.value }}</text>
|
||||
<text class="metric-unit">{{ item.unit }}</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<!-- 轧制力趋势 -->
|
||||
<view class="section">
|
||||
<view class="section-title">轧制力趋势</view>
|
||||
<view class="chart-box">
|
||||
<qiun-data-charts type="line" :chartData="forceChartData" :opts="lineChartOpts" />
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<!-- 带钢张力 -->
|
||||
<view class="section">
|
||||
@@ -78,8 +78,8 @@
|
||||
<text class="metric-name">{{ item.label }}</text>
|
||||
<text class="metric-value">{{ item.value }}</text>
|
||||
<text class="metric-unit">{{ item.unit }}</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<!-- 功率百分比 -->
|
||||
@@ -90,8 +90,8 @@
|
||||
<text class="metric-name">{{ item.label }}</text>
|
||||
<text class="metric-value">{{ item.value }}</text>
|
||||
<text class="metric-unit">{{ item.unit }}</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
</scroll-view>
|
||||
|
||||
@@ -402,7 +402,7 @@ export default {
|
||||
|
||||
this.forceChartData = {
|
||||
categories: categories.reverse(),
|
||||
series: [
|
||||
series: [
|
||||
{ name: '1#轧制力', data: force1Data.reverse() },
|
||||
{ name: '2#轧制力', data: force2Data.reverse() },
|
||||
{ name: '3#轧制力', data: force3Data.reverse() },
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
// 应用全局配置
|
||||
module.exports = {
|
||||
// baseUrl: 'http://192.168.31.116:8080',
|
||||
baseUrl: 'http://140.143.206.120:8080',
|
||||
baseUrl: 'http://192.168.31.116:8080',
|
||||
// baseUrl: 'http://140.143.206.120:8080',
|
||||
// baseUrl: 'http://localhost:8080',
|
||||
// 应用信息
|
||||
appInfo: {
|
||||
|
||||
@@ -27,11 +27,14 @@
|
||||
<script>
|
||||
import { getDicts } from '@/api/system/dict/data.js'
|
||||
import { getGenerateRecord } from '@/api/wms/code.js'
|
||||
import { getMaterialCoil } from '@/api/wms/coil.js'
|
||||
import { addPendingAction } from '@/api/wms/pendingAction.js'
|
||||
|
||||
export default {
|
||||
data() {
|
||||
return {
|
||||
types: []
|
||||
types: [],
|
||||
loading: false
|
||||
}
|
||||
},
|
||||
methods: {
|
||||
@@ -42,12 +45,146 @@
|
||||
})
|
||||
})
|
||||
},
|
||||
handleScan(type) {
|
||||
|
||||
// 扫码并创建待操作
|
||||
handleScan(actionType) {
|
||||
uni.scanCode({
|
||||
success(res) {
|
||||
const result = res.result;
|
||||
success: async (res) => {
|
||||
console.log('=== 开始扫码流程 ===');
|
||||
console.log('扫码结果:', res.result);
|
||||
console.log('操作类型:', actionType);
|
||||
uni.showLoading({ title: '处理中...' });
|
||||
|
||||
try {
|
||||
const qrcodeId = res.result;
|
||||
// 1. 通过二维码ID获取二维码详情
|
||||
console.log('1. 获取二维码详情,ID:', qrcodeId);
|
||||
const qrcodeRes = await getGenerateRecord(qrcodeId);
|
||||
console.log('二维码响应:', qrcodeRes);
|
||||
|
||||
if (qrcodeRes.code !== 200) {
|
||||
throw new Error('未找到二维码记录');
|
||||
}
|
||||
|
||||
// 2. 解析二维码的content,获取coil_id
|
||||
const qrcodeRecord = qrcodeRes.data;
|
||||
console.log('2. 二维码记录:', qrcodeRecord);
|
||||
|
||||
// 检查二维码状态(0=失效,1=有效)
|
||||
if (qrcodeRecord.status === 0) {
|
||||
uni.hideLoading();
|
||||
uni.showModal({
|
||||
title: '提示',
|
||||
content: '该二维码已失效,无法创建待操作任务',
|
||||
showCancel: false
|
||||
});
|
||||
return;
|
||||
}
|
||||
|
||||
const content = JSON.parse(qrcodeRecord.content);
|
||||
console.log('解析后的内容:', content);
|
||||
|
||||
// 优先使用current_coil_id(当前有效的钢卷ID),如果没有则使用coil_id(兼容旧数据)
|
||||
let coilId = content.current_coil_id && content.current_coil_id !== 'null' ? content.current_coil_id : null;
|
||||
if (!coilId) {
|
||||
coilId = content.coil_id && content.coil_id !== 'null' ? content.coil_id : null;
|
||||
}
|
||||
|
||||
console.log('提取钢卷ID - current_coil_id:', content.current_coil_id, 'coil_id:', content.coil_id, '最终使用:', coilId);
|
||||
|
||||
if (!coilId) {
|
||||
throw new Error('二维码中未包含有效的钢卷ID');
|
||||
}
|
||||
|
||||
// 3. 直接通过钢卷ID获取钢卷详情
|
||||
console.log('3. 获取钢卷详情,钢卷ID:', coilId);
|
||||
const coilRes = await getMaterialCoil(coilId);
|
||||
console.log('钢卷详情响应:', coilRes);
|
||||
|
||||
if (coilRes.code !== 200) {
|
||||
throw new Error(coilRes.msg || '查询钢卷信息失败');
|
||||
}
|
||||
|
||||
if (!coilRes.data) {
|
||||
throw new Error('未找到钢卷信息');
|
||||
}
|
||||
|
||||
const coilData = coilRes.data;
|
||||
console.log('4. 钢卷数据:', coilData);
|
||||
|
||||
// 4. 创建待操作记录
|
||||
const pendingData = {
|
||||
coilId: coilData.coilId,
|
||||
currentCoilNo: coilData.currentCoilNo,
|
||||
actionType: parseInt(actionType),
|
||||
actionStatus: 0, // 待处理
|
||||
sourceType: 'scan', // 扫码来源
|
||||
scanTime: new Date().toISOString(),
|
||||
scanDevice: this.getDeviceInfo(),
|
||||
warehouseId: coilData.warehouseId,
|
||||
priority: 0, // 默认普通优先级
|
||||
remark: `移动端扫码创建 - ${this.getActionTypeName(actionType)}`
|
||||
};
|
||||
|
||||
console.log('5. 创建待操作记录,数据:', pendingData);
|
||||
|
||||
const addRes = await addPendingAction(pendingData);
|
||||
console.log('创建待操作响应:', addRes);
|
||||
|
||||
if (addRes.code !== 200) {
|
||||
throw new Error(addRes.msg || '创建待操作失败');
|
||||
}
|
||||
|
||||
uni.hideLoading();
|
||||
console.log('=== 扫码流程完成 ===');
|
||||
uni.showToast({
|
||||
title: '创建成功',
|
||||
icon: 'success',
|
||||
duration: 2000
|
||||
});
|
||||
|
||||
// 延迟后返回或跳转
|
||||
setTimeout(() => {
|
||||
// 可以跳转到待操作列表或返回上一页
|
||||
uni.navigateBack();
|
||||
}, 2000);
|
||||
|
||||
} catch (err) {
|
||||
console.error('=== 扫码处理失败 ===');
|
||||
console.error('错误信息:', err);
|
||||
console.error('错误堆栈:', err.stack);
|
||||
uni.hideLoading();
|
||||
uni.showToast({
|
||||
title: err.message || '处理失败',
|
||||
icon: 'none',
|
||||
duration: 3000
|
||||
});
|
||||
}
|
||||
},
|
||||
fail: (err) => {
|
||||
console.error('扫码失败:', err);
|
||||
uni.showToast({
|
||||
title: '扫码失败,请重试',
|
||||
icon: 'none'
|
||||
});
|
||||
}
|
||||
})
|
||||
});
|
||||
},
|
||||
|
||||
// 获取设备信息
|
||||
getDeviceInfo() {
|
||||
try {
|
||||
const systemInfo = uni.getSystemInfoSync();
|
||||
return `${systemInfo.platform} ${systemInfo.model}`;
|
||||
} catch (e) {
|
||||
return 'Unknown Device';
|
||||
}
|
||||
},
|
||||
|
||||
// 获取操作类型名称
|
||||
getActionTypeName(actionType) {
|
||||
const type = this.types.find(t => t.dictValue === String(actionType));
|
||||
return type ? type.dictLabel : '未知操作';
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
|
||||
Reference in New Issue
Block a user