freight-web/src/pagesReceive/form/pricingForm.vue

514 lines
12 KiB
Vue
Raw Normal View History

2024-03-09 12:37:17 +00:00
<template>
<view class="c-card">
<u-form
labelPosition="left"
:model="model1"
:rules="rules"
ref="form"
:labelWidth="80"
:labelStyle="{ padding: '0rpx 10rpx' }"
2024-03-21 05:52:15 +00:00
:errorType="'border-bottom'"
2024-03-09 12:37:17 +00:00
>
<u-form-item
2024-03-21 05:52:15 +00:00
:prop="`order.${item.key}`"
2024-03-09 12:37:17 +00:00
:label="item.name"
:required="item.required"
v-for="(item, index) in formAttrList"
:key="index"
@click="item.fn"
2024-03-21 05:52:15 +00:00
:borderBottom="false"
2024-03-09 12:37:17 +00:00
>
<u-textarea
v-if="item.type === 'textarea'"
v-model="(model1.order as any)[item.key]"
:placeholder="`请输入${item.name}`"
></u-textarea>
<u-input
v-if="item.type === 'select' || item.type === 'input'"
v-model="(model1.order as any)[item.key]"
:placeholder="`${item.type === 'select' ? '选择' : '输入'}${
item.name
}`"
:clearable="true"
:customStyle="{}"
border="none"
>
<template #suffix>
<text v-if="item.key === 'subtractNum'">
{{ model1.order.buttonType === 0 ? item.unit : "%" }}
</text>
<text v-else>
{{ item.unit }}
</text>
</template>
</u-input>
<!-- @afterRead="afterRead"
@delete="deletePic" -->
<uni-file-picker
v-if="item.type === 'upload'"
2024-03-21 05:52:15 +00:00
:limit="10"
2024-03-09 12:37:17 +00:00
title="最多可上传10张图片"
:auto-upload="false"
fileMediatype="image"
ref="filesRef"
2024-03-21 05:52:15 +00:00
v-model="model1.order.fileLists"
@delete="handleDelete"
2024-03-09 12:37:17 +00:00
></uni-file-picker>
<u-radio-group
v-if="item.type === 'radio'"
v-model="(model1.order as any)[item.key]"
placement="row"
>
<u-radio
v-for="(c, index) in item.child"
:key="index"
activeColor="#00DCEE"
:label="c.name"
:name="c.id"
:customStyle="{ marginRight: '10px' }"
></u-radio>
</u-radio-group>
<template #right v-if="item.type === 'select'">
<u-icon name="arrow-right"></u-icon>
</template>
</u-form-item>
</u-form>
<block v-for="(item, index) in formAttrList" :key="index">
<u-action-sheet
v-if="item.type === 'select'"
:actions="contrlModalParams[item.childKey].list"
:title="contrlModalParams[item.childKey].title"
:show="contrlModalParams[item.childKey].isShow"
@select="(v: any) => handleSelect(item.childKey, v)"
@close="contrlModalParams[item.childKey].isShow = false"
:closeOnClickAction="true"
2024-03-21 05:58:34 +00:00
:safeAreaInsetBottom="true"
2024-03-09 12:37:17 +00:00
></u-action-sheet>
</block>
</view>
<view class="btn-box">
2024-03-21 05:52:15 +00:00
<u-button text="暂不定价" @click="handleBack()"></u-button>
2024-03-09 12:37:17 +00:00
<u-button type="primary" text="保存" @click="save()"></u-button>
</view>
</template>
<script setup lang="ts">
import type { ComType } from "@/types/global";
import {
ProfileApi,
ReceiveProductApi,
ReceiveApi,
PictureApi,
2024-03-21 05:58:34 +00:00
SupplierApi,
2024-03-09 12:37:17 +00:00
} from "@/services/index";
import _ from "underscore";
import { onLoad } from "@dcloudio/uni-app";
import { ImagesType, OrderType } from "@/utils/enum";
const model1 = reactive<{ order: Order }>({
order: {
id: 0,
userName: "", // 供应商名称
userId: "", // 供应商Id,
carNumber: "",
productId: "", // 产品Id,
productName: "", // 产品名称
price: "", // 单价
buttonType: 0, // 0扣杂1扣点
weighingMethod: 0, // 0有皮重 1零皮重
multiCategory: 0, // 0单品类 1多品类
2024-03-21 05:52:15 +00:00
fileLists: [],
2024-03-09 12:37:17 +00:00
scaleStatus: 1,
},
});
2024-03-21 05:52:15 +00:00
const rules = reactive({
"order.userName": {
2024-03-09 12:37:17 +00:00
type: "string",
required: true,
2024-03-21 05:52:15 +00:00
message: "请输入选择供应商",
2024-03-09 12:37:17 +00:00
trigger: ["blur", "change"],
},
2024-03-21 05:52:15 +00:00
"order.productName": {
2024-03-09 12:37:17 +00:00
type: "string",
required: true,
2024-03-21 05:52:15 +00:00
message: "请选择收货产品名称",
trigger: ["blur", "change"],
},
"order.price": {
type: "number",
required: true,
message: "请输入单价",
trigger: ["blur", "change"],
},
"order.grossWeight": {
type: "number",
required: true,
message: "请输入毛重",
trigger: ["blur", "change"],
},
"order.weighingMethod": {
type: "number",
required: true,
message: "请选择称重方式",
trigger: ["blur", "change"],
},
"order.multiCategory": {
type: "number",
required: true,
message: "请选择品类",
2024-03-09 12:37:17 +00:00
trigger: ["blur", "change"],
},
});
const contrlModalParams = reactive<ComType>({
isShowSplTime: false,
spltime: "",
userSelect: {
isShow: false,
title: "标题",
list: [],
},
productSelect: {
isShow: false,
title: "标题",
list: [],
},
});
const formAttrList = reactive<ComType>([
{
name: "供应商",
key: "userName",
type: "select",
unit: "",
childKey: "userSelect",
required: true,
fn: () => {
contrlModalParams.userSelect.isShow = true;
contrlModalParams.userSelect.title = "供应商";
},
},
{
name: "车牌号",
key: "carNumber",
type: "input",
unit: "",
},
{
name: "收货产品",
key: "productName",
type: "select",
unit: "",
childKey: "productSelect",
required: true,
fn: () => {
contrlModalParams.productSelect.isShow = true;
contrlModalParams.productSelect.title = "收货产品";
},
},
{
name: "单价",
key: "price",
type: "input",
unit: "元/KG",
required: true,
},
{
name: "毛重",
key: "grossWeight",
type: "input",
unit: "KG",
required: true,
},
{
name: "扣杂",
key: "buttonType",
type: "radio",
child: [
{
id: 0,
name: "按固定重量",
},
{
id: 1,
name: "按百分比",
},
],
},
{
name: "杂质扣除",
key: "subtractNum",
type: "input",
unit: "KG",
},
{
name: "称重方式",
key: "weighingMethod",
type: "radio",
required: true,
child: [
{
id: 0,
name: "有皮重",
},
{
id: 1,
name: "零皮重",
},
],
},
{
name: "多品类",
key: "multiCategory",
type: "radio",
required: true,
child: [
{
id: 0,
name: "单品类",
},
{
id: 1,
name: "多品类",
},
],
},
{
name: "备注",
key: "notes",
type: "textarea",
},
{
name: "货品照片",
key: "photo",
type: "upload",
},
]);
2024-03-21 05:58:34 +00:00
SupplierApi.getSupplierUserList({}).then((res) => {
2024-03-09 12:37:17 +00:00
if (res.code === 200) {
contrlModalParams.userSelect.list = res.data;
}
});
ReceiveProductApi.getAllReProducts().then((res) => {
if (res.code === 200) {
contrlModalParams.productSelect.list = _.map(
res.data as any,
function (item: any) {
return { name: item.reProductsName, ...item };
}
);
}
});
const handleSelect = (key: string, v: any) => {
contrlModalParams[key].isShow = false;
if (key === "userSelect") {
model1.order.userName = v.name;
model1.order.userId = v.id;
} else if (key === "productSelect") {
model1.order.productName = v.name;
model1.order.productId = v.id;
}
};
2024-03-21 05:52:15 +00:00
const handleBack = () => {
uni.navigateBack();
};
2024-03-09 12:37:17 +00:00
// const files = ref<FileObj[]>([]);
const filesRef = ref();
const handleUpload = () => {
// console.log(event.tempFilePaths)
2024-03-21 05:52:15 +00:00
return filesRef.value[0].filesList.map((item: any, index: number) => {
if (item.fileID) {
return;
}
2024-03-09 12:37:17 +00:00
return new Promise((resolve) => {
PictureApi.upload({
files: item,
path: item.path,
2024-03-21 05:52:15 +00:00
})
.then((res) => {
if (res.code === 200) {
resolve({
...(res.data as any),
businessId: model1.order.id,
imagesType: ImagesType.NORMARL, // 普通资源
orderType: OrderType.Receive, // 入库单
});
}
})
.catch((e) => {
return;
});
2024-03-09 12:37:17 +00:00
});
});
};
2024-03-21 05:52:15 +00:00
/**
*
*/
const handleDelete = (e: any) => {
console.log(model1.order.fileLists);
if (e.tempFile.fileID) {
PictureApi.deleteById({ id: e.tempFile.fileID }).then((res) => {
if (res.code === 200) {
uni.showToast({ title: "已删除" });
}
});
}
};
2024-03-09 12:37:17 +00:00
/**
* 点击保存 先执行upload接口
* 上传成功后 保存图片资源 和更新订单数据
*/
2024-03-21 05:52:15 +00:00
const form = ref();
const check = () => {
return new Promise((resolve) => {
form.value
.validate()
.then((res: boolean) => {
resolve(res);
})
.catch((errors: any) => {
resolve(false);
uni.showToast({
icon: "none",
title: errors[0].message || "校验失败",
});
});
});
};
2024-03-09 12:37:17 +00:00
const save = () => {
2024-03-21 05:52:15 +00:00
check().then((res) => {
if (res) {
startSave();
}
});
};
const startSave = () => {
2024-03-09 12:37:17 +00:00
Promise.all(handleUpload()).then((res) => {
2024-03-21 05:52:15 +00:00
if (res.filter((item) => item).length > 0) {
PictureApi.addListAnnex({ annexPos: res.filter((item) => item) }).then(
(res1) => {
if (res1.code === 200) {
2024-03-22 05:45:34 +00:00
console.log("*** 资源文件更新成功");
2024-03-21 05:52:15 +00:00
}
2024-03-09 12:37:17 +00:00
}
2024-03-21 05:52:15 +00:00
);
2024-03-09 12:37:17 +00:00
}
});
2024-03-22 05:45:34 +00:00
updateOrder();
2024-03-21 05:52:15 +00:00
};
2024-03-09 12:37:17 +00:00
2024-03-21 05:52:15 +00:00
const updateOrder = () => {
2024-03-09 12:37:17 +00:00
// 更新定价单
/**
* 0有皮重 1零皮重
* 有皮重 scaleState = 1 带过皮
零皮重 scaleState = 2 带审核
*/
if (model1.order.weighingMethod === 0) {
model1.order.scaleStatus = 1;
} else if (model1.order.weighingMethod === 1) {
model1.order.scaleStatus = 2;
}
//
/**
* buttonType
* 0扣杂1扣点
* buttonType===0 buckleMiscellaneous
* buttonType===1 points
*
*/
if (model1.order.buttonType === 0) {
model1.order.buckleMiscellaneous = model1.order.subtractNum;
} else if (model1.order.buttonType === 1) {
model1.order.points = model1.order.subtractNum;
}
ReceiveApi.updateOne({ ...model1.order }).then((res) => {
if (res.code === 200) {
// 定价后 若是零皮-》跳转到【付款审核】 有皮重->【待过皮重】
2024-03-22 05:45:34 +00:00
// 当上一页为审核页
if (prePage.value === "review") {
uni.redirectTo({
url:
"/pagesReceive/review/index?id=" +
model1.order.id +
`&scaleStatus=` +
model1.order.scaleStatus, // 要跳转到的页面路径
});
} else {
// 0有皮重 1零皮重
uni.redirectTo({
url: "/pagesHome/index", // 要跳转到的页面路径
});
}
2024-03-09 12:37:17 +00:00
}
});
};
2024-03-22 05:45:34 +00:00
const prePage = ref("");
2024-03-21 05:52:15 +00:00
onLoad((option) => {
model1.order.id = parseInt((option as any).id);
2024-03-22 05:45:34 +00:00
prePage.value = (option as any).prePage;
2024-03-21 05:52:15 +00:00
if (model1.order.id) {
ReceiveApi.getDetailById({ id: model1.order.id }).then((res) => {
if (res.code === 200) {
// 基于id查询重新赋值
model1.order = {
...res.data,
buttonType: res.data.buttonType !== null ? res.data.buttonType : 0,
weighingMethod:
res.data.weighingMethod !== null ? res.data.weighingMethod : 0,
multiCategory:
res.data.multiCategory !== null ? res.data.multiCategory : 0,
fileLists: model1.order.fileLists.map((item: any) => {
return { ...item, fileID: item.id };
}),
};
}
});
PictureApi.getAnnex({
businessId: model1.order.id.toString(),
orderType: 1,
imagesType: ImagesType.NORMARL,
}).then((res) => {
if (res.code === 200) {
model1.order.fileLists = res.data;
}
});
}
});
2024-03-09 12:37:17 +00:00
</script>
<style lang="scss" scoped>
.c-card {
background: #ffffff;
// box-shadow: 0rpx 0rpx 10rpx 0rpx rgba(5, 68, 37, 0.12);
border-radius: 13rpx;
margin: 30rpx 25rpx;
2024-03-21 05:52:15 +00:00
padding: 0rpx 20rpx;
2024-03-09 12:37:17 +00:00
::v-deep .u-form-item {
height: auto;
}
::v-deep .u-form-item + .u-form-item {
border-top: 1rpx solid rgba(233, 233, 233, 0.76);
}
}
.btn-box {
margin-top: 60rpx;
display: flex;
background: #ffffff;
box-shadow: 0rpx 0rpx 10rpx 0rpx rgba(0, 56, 93, 0.12);
border-radius: 13rpx 13rpx 0rpx 0rpx;
padding: 25rpx 50rpx;
2024-03-19 02:15:47 +00:00
position: sticky;
2024-03-09 12:37:17 +00:00
bottom: 0rpx;
z-index: 999;
::v-deep button {
border-radius: 43rpx;
}
::v-deep button + button {
margin-left: 30rpx;
}
}
</style>