From e1e2fe5710a5b5cd9c19bd3aa99c998a1a613ca8 Mon Sep 17 00:00:00 2001
From: quanwei <419654421@qq.com>
Date: Sat, 17 Jan 2026 17:58:01 +0800
Subject: [PATCH] 团购组件增加筛选
---
mobile/pages/user/my_shop/product_edit.vue | 97 +++++++++++++++++++++++++++++++++++-------------
1 files changed, 71 insertions(+), 26 deletions(-)
diff --git a/mobile/pages/user/my_shop/product_edit.vue b/mobile/pages/user/my_shop/product_edit.vue
index 7328aaf..cef0431 100644
--- a/mobile/pages/user/my_shop/product_edit.vue
+++ b/mobile/pages/user/my_shop/product_edit.vue
@@ -47,9 +47,13 @@
<view class="form-item" v-if="form.model.is_preview === 1">
<view class="item-label">预告开启购买时间</view>
- <picker mode="datetime" class="item-picker" @change="previewTimeChange" :value="previewTimeArray">
+ <uni-datetime-picker class="item-picker"
+ :value="previewTime"
+ @change="previewTimeChange"
+ :start="'1970-01-01'"
+ :end="'2030-12-31'">
<view class="picker-text">{{ previewTimeText || '请选择预告时间' }}</view>
- </picker>
+ </uni-datetime-picker>
</view>
<view class="form-item">
@@ -133,6 +137,8 @@
@click="form.model.is_virtual = 1">虚拟商品</view>
<view class="radio-item" :class="{ active: form.model.is_virtual === 2 }"
@click="form.model.is_virtual = 2">券商品</view>
+ <view class="radio-item" :class="{ active: form.model.is_virtual === 3 }"
+ @click="form.model.is_virtual = 3">服务商品</view>
</view>
</view>
@@ -165,7 +171,7 @@
</view>
<!-- 虚拟商品设置 -->
- <view class="form-item" v-if="form.model.is_virtual === 1">
+ <view class="form-item" v-if="form.model.is_virtual === 1 || form.model.is_virtual === 3">
<view class="item-label">发货类型</view>
<view class="radio-group">
<view class="radio-item" :class="{ active: form.model.virtual_auto === 1 }"
@@ -175,12 +181,17 @@
</view>
</view>
- <view class="form-item" v-if="form.model.is_virtual === 1">
+ <view class="form-item" v-if="form.model.is_virtual === 1 ">
<view class="item-label">虚拟内容</view>
<input class="item-input" v-model="form.model.virtual_content" placeholder="请输入虚拟物品内容" />
</view>
- <view class="form-item" v-if="form.model.is_virtual === 1 && form.model.virtual_auto === 0">
+ <view class="form-item" v-if=" form.model.is_virtual === 3">
+ <view class="item-label">服务商品内容</view>
+ <input class="item-input" v-model="form.model.service_content" placeholder="请输入服务商品内容" />
+ </view>
+
+ <view class="form-item" v-if="(form.model.is_virtual === 1 || form.model.is_virtual === 3) && form.model.virtual_auto === 0">
<view class="item-label">支持线下核销</view>
<view class="radio-group">
<view class="radio-item" :class="{ active: form.model.is_verify === 1 }"
@@ -191,7 +202,7 @@
</view>
<view class="form-item"
- v-if="form.model.is_virtual === 1 && form.model.virtual_auto === 0 && form.model.is_verify === 1">
+ v-if="(form.model.is_virtual === 1 || form.model.is_virtual === 3) && form.model.virtual_auto === 0 && form.model.is_verify === 1">
<view class="item-label">核销到期类型</view>
<view class="radio-group">
<view class="radio-item" :class="{ active: form.model.verify_type === 10 }"
@@ -202,14 +213,14 @@
</view>
<view class="form-item"
- v-if="form.model.is_virtual === 1 && form.model.virtual_auto === 0 && form.model.is_verify === 1 && form.model.verify_type === 10">
+ v-if="(form.model.is_virtual === 1 || form.model.is_virtual === 3) && form.model.virtual_auto === 0 && form.model.is_verify === 1 && form.model.verify_type === 10">
<view class="item-label">核销有效天数</view>
<input class="item-input" v-model="form.model.verify_day" placeholder="请输入有效天数,0或留空表示永久有效"
type="number" />
</view>
<view class="form-item"
- v-if="form.model.is_virtual === 1 && form.model.virtual_auto === 0 && form.model.is_verify === 1 && form.model.verify_type === 20">
+ v-if="(form.model.is_virtual === 1 || form.model.is_virtual === 3) && form.model.virtual_auto === 0 && form.model.is_verify === 1 && form.model.verify_type === 20">
<view class="item-label">核销有效时间</view>
<picker mode="daterange" class="item-picker" @change="verifyTimeChange" :value="verifyTimeArray">
<view class="picker-text">{{ verifyTimeText || '请选择核销有效时间' }}</view>
@@ -346,15 +357,15 @@
<view class="form-item">
<view class="item-label">详情类型</view>
<view class="radio-group">
- <view class="radio-item" :class="{ active: form.model.content_type === 10 }"
- @click="form.model.content_type = 10">图文</view>
- <view class="radio-item" :class="{ active: form.model.content_type === 20 }"
- @click="form.model.content_type = 20">纯图</view>
+ <view class="radio-item" :class="{ active: form.model.is_picture == 0 }"
+ @click="form.model.is_picture = 0">图文</view>
+ <view class="radio-item" :class="{ active: form.model.is_picture == 1 }"
+ @click="form.model.is_picture = 1">纯图</view>
</view>
</view>
<!-- 图文类型 -->
- <view v-if="form.model.content_type === 10" class="form-item">
+ <view v-if="form.model.is_picture == 0" class="form-item">
<view class="item-label">商品详情</view>
<view class="editor">
<!-- 富文本编辑器 -->
@@ -445,7 +456,7 @@
</view>
<!-- 纯图类型 -->
- <view v-else-if="form.model.content_type === 20" class="form-item">
+ <view v-else-if="form.model.is_picture == 1" class="form-item">
<view class="item-label">商品详情图片</view>
<view class="uploader">
<view class="uploader-item" v-for="(item, index) in form.model.contentImage" :key="index">
@@ -470,7 +481,7 @@
<view class="item-label">积分设置</view>
<view class="switch-item">
<view class="switch-label">开启积分赠送</view>
- <switch v-model="form.model.is_points_gift" />
+ <switch :checked="form.model.is_points_gift" v-model="form.model.is_points_gift" />
</view>
<view class="switch-item">
<view class="switch-label">允许积分抵扣</view>
@@ -487,7 +498,7 @@
<view class="item-label">团队分红设置</view>
<view class="switch-item">
<view class="switch-label">是否参与团队分红</view>
- <switch checked v-model="form.model.is_enable_team" />
+ <switch :checked="form.model.is_enable_team==1?true:false" v-model="form.model.is_enable_team" />
</view>
</view>
</view>
@@ -519,6 +530,7 @@
deliveryIndex: 0,
// 预告时间相关
previewTimeArray: [now.getFullYear(), now.getMonth(), now.getDate(), now.getHours(), now.getMinutes()],
+ previewTime: '',
previewTimeText: '',
// 核销时间相关
verifyTimeArray: [],
@@ -548,7 +560,7 @@
selling_point: '',
spec_type: 10,
deduct_stock_type: 20,
- content_type: 10,
+ is_picture: 0,
sku: {
product_no: '',
product_price: '',
@@ -583,6 +595,7 @@
deduction_price: 0,
virtual_auto: 0,
virtual_content: '',
+ service_content: '',
is_preview: 0,
preview_time: '',
is_verify: 0,
@@ -641,20 +654,52 @@
product_id: self.productId
}, (res) => {
// 合并默认值和后端返回的数据,确保 spec_many 字段始终存在
+ Object.assign(self.form, res.data);
self.form.model = Object.assign({
spec_many: {
spec_attr: [],
spec_list: []
}
}, res.data.model);
+
+ // 处理单规格商品的 sku 字段,后端返回的是数组,前端需要对象
+ if (self.form.model.spec_type === 10 && Array.isArray(self.form.model.sku) && self.form.model.sku.length > 0) {
+ self.form.model.sku = self.form.model.sku[0];
+ }
+ self.form.model.product_status = res.data.model.product_status.value;
+ if(self.form.model.delivery_id == 0){
+ self.$set(self.form.model, 'is_delivery_free', 0);
+ }else{
+ self.$set(self.form.model, 'is_delivery_free', 1);
+ }
+ if(self.form.model.notice == null){
+ self.form.model.notice = [];
+ }
+ //修改时审核状态
+ if(self.form.audit_setting.edit_audit == 1 && self.form.scene != 'add'){
+ self.form.model.audit_status = 0;
+ }
+ if (self.form.model.content) {
+ setTimeout(function(){
+ self.editorCtx.setContents({
+ html: self.form.model.content
+ });
+ },1000)
+ }
// 设置分类索引
self.categoryIndex = self.form.category.findIndex(item => item.category_id === self.form
.model.category_id);
- self.selectedCategory = self.form.category[self.categoryIndex]?.category_name;
+ self.selectedCategory = self.form.category[self.categoryIndex]?.name;
// 设置运费模板索引
self.deliveryIndex = self.form.delivery.findIndex(item => item.delivery_id === self.form
.model.delivery_id);
- self.selectedDelivery = self.form.delivery[self.deliveryIndex]?.delivery_name;
+ self.selectedDelivery = self.form.delivery[self.deliveryIndex]?.name;
+ // 设置预告时间
+ if (self.form.model.is_preview === 1 && self.form.model.preview_time) {
+ const previewDate = new Date(self.form.model.preview_time * 1000);
+ self.previewTime = previewDate.toISOString().slice(0, 16);
+ self.previewTimeText = self.previewTime;
+ }
self.loading = false;
});
},
@@ -692,9 +737,9 @@
// 选择预告时间
previewTimeChange(e) {
const date = new Date(e.detail.value);
- this.form.model.preview_time = date.toISOString().slice(0, 19).replace('T', ' ');
- this.previewTimeText =
- `${date.getFullYear()}-${(date.getMonth() + 1).toString().padStart(2, '0')}-${date.getDate().toString().padStart(2, '0')} ${date.getHours().toString().padStart(2, '0')}:${date.getMinutes().toString().padStart(2, '0')}`;
+ this.form.model.preview_time = Math.floor(date.getTime() / 1000);
+ this.previewTime = e.detail.value;
+ this.previewTimeText = e.detail.value;
},
// 选择视频
@@ -1020,7 +1065,7 @@
save() {
let self = this;
// 先获取富文本编辑器内容
- if (self.form.model.content_type === 10 && self.editorCtx) {
+ if (self.form.model.is_picture == 0 && self.editorCtx) {
// 图文类型,获取编辑器内容
self.editorCtx.getContents({
success: (res) => {
@@ -1118,7 +1163,7 @@
}
// 根据详情类型验证内容
- if (self.form.model.content_type === 10) {
+ if (self.form.model.is_picture == 0) {
// 图文类型,验证富文本内容
if (!self.form.model.content || self.form.model.content.trim() === '') {
uni.showToast({
@@ -1127,7 +1172,7 @@
});
return;
}
- } else if (self.form.model.content_type === 20) {
+ } else if (self.form.model.is_picture == 1) {
// 纯图类型,验证详情图片
if (self.form.model.contentImage.length === 0) {
uni.showToast({
@@ -1137,7 +1182,7 @@
return;
}
}
-
+
self.loading = true;
self._post('supplier.product/edit', {
product_id: self.productId,
--
Gitblit v1.9.2