2026-01-19 16:52:24 +08:00
|
|
|
|
<template>
|
|
|
|
|
|
<view class="container">
|
|
|
|
|
|
<!-- 顶部状态栏/时间 -->
|
|
|
|
|
|
<view class="status-bar">
|
|
|
|
|
|
<text class="time">9:41</text>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- 搜索栏 -->
|
|
|
|
|
|
<view class="search-bar">
|
|
|
|
|
|
<view class="search-input">
|
|
|
|
|
|
<uni-icons type="search" size="18" color="#999"></uni-icons>
|
|
|
|
|
|
<input
|
|
|
|
|
|
type="text"
|
2026-01-26 19:57:03 +08:00
|
|
|
|
placeholder="搜索商品条码"
|
2026-01-19 16:52:24 +08:00
|
|
|
|
placeholder-class="placeholder"
|
|
|
|
|
|
v-model="searchText"
|
|
|
|
|
|
@confirm="onSearch"
|
|
|
|
|
|
/>
|
|
|
|
|
|
<uni-icons type="scan" size="18" color="#999"></uni-icons>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- 筛选标签 -->
|
|
|
|
|
|
<view class="filter-tabs">
|
|
|
|
|
|
<scroll-view class="tabs-scroll" scroll-x="true">
|
|
|
|
|
|
<view
|
|
|
|
|
|
class="tab-item"
|
|
|
|
|
|
:class="{ active: currentTab === 'all' }"
|
|
|
|
|
|
@tap="switchTab('all')"
|
|
|
|
|
|
>
|
|
|
|
|
|
全部
|
|
|
|
|
|
</view>
|
|
|
|
|
|
<view
|
2026-02-04 16:55:43 +08:00
|
|
|
|
class="tab-item"
|
|
|
|
|
|
:class="{ active: currentTab === 'expiring' }"
|
|
|
|
|
|
@tap="switchTab('expiring')"
|
|
|
|
|
|
>
|
|
|
|
|
|
临期/过期<text class="badge">0</text>
|
|
|
|
|
|
</view>
|
2026-01-19 16:52:24 +08:00
|
|
|
|
<view
|
|
|
|
|
|
class="tab-item"
|
|
|
|
|
|
:class="{ active: currentTab === 'outstock' }"
|
|
|
|
|
|
@tap="switchTab('outstock')"
|
|
|
|
|
|
>
|
|
|
|
|
|
缺货<text class="badge">0</text>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
<view class="tab-item filter-btn" @tap="showFilter = !showFilter">
|
|
|
|
|
|
<text>筛选</text>
|
|
|
|
|
|
<uni-icons type="arrowdown" size="14" color="#666"></uni-icons>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
</scroll-view>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- 微店状态栏 -->
|
2026-02-04 16:55:43 +08:00
|
|
|
|
<view class="store-status" v-if="currentTab === 'all'">
|
2026-01-19 16:52:24 +08:00
|
|
|
|
<view class="status-content">
|
|
|
|
|
|
<view class="dui">
|
2026-03-28 22:33:20 +08:00
|
|
|
|
<image class="dui-img" :src="apiUrl + '/static/images/Frame 52.png'"></image>
|
2026-01-19 16:52:24 +08:00
|
|
|
|
</view>
|
|
|
|
|
|
<view class="status-left">
|
|
|
|
|
|
<text class="status-text">已开启微店商店库</text>
|
|
|
|
|
|
<text class="status-num">微店商品库全226+商品</text>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
<view class="status-right" @tap="goToSettings">
|
|
|
|
|
|
<text class="set-text">设置</text>
|
|
|
|
|
|
<uni-icons type="forward" size="14" color="#666"></uni-icons>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
|
2026-02-04 16:55:43 +08:00
|
|
|
|
<!-- 临期/过期状态栏 -->
|
|
|
|
|
|
<view class="store-status" v-else-if="currentTab === 'expiring'">
|
|
|
|
|
|
<view class="status-left-content">
|
|
|
|
|
|
<view class="dui">
|
2026-03-28 22:33:20 +08:00
|
|
|
|
<image class="dui-img" :src="apiUrl + '/static/images/Mask group.png'"></image>
|
2026-02-04 16:55:43 +08:00
|
|
|
|
</view>
|
|
|
|
|
|
<view class="status-left">
|
|
|
|
|
|
<text class="status-text">快速处理</text>
|
|
|
|
|
|
<text class="status-num">临期/过期食品</text>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
<view class="status-right-buttons">
|
|
|
|
|
|
<view class="quick-btn pink-btn" @tap="goToPromotion">
|
|
|
|
|
|
<text class="btn-text">临期促销</text>
|
|
|
|
|
|
<uni-icons type="arrowright" size="12" color="#fff"></uni-icons>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
<view class="quick-btn pink-btn" @tap="goToExpiredOut">
|
|
|
|
|
|
<text class="btn-text">过期出库</text>
|
|
|
|
|
|
<uni-icons type="arrowright" size="12" color="#fff"></uni-icons>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- 缺货状态栏 -->
|
|
|
|
|
|
<view class="store-status" v-else-if="currentTab === 'outstock'">
|
|
|
|
|
|
<view class="status-content">
|
|
|
|
|
|
<view class="dui">
|
2026-03-28 22:33:20 +08:00
|
|
|
|
<image class="dui-img" :src="apiUrl + '/static/images/Mask group (1).png'"></image>
|
2026-02-04 16:55:43 +08:00
|
|
|
|
</view>
|
|
|
|
|
|
<view class="status-left">
|
|
|
|
|
|
<text class="status-text">库存不足预警设置</text>
|
|
|
|
|
|
<text class="status-num">库存低于已设置阈值时,会收到APP推送提醒</text>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
<view class="status-right" @tap="goToAlertSettings">
|
|
|
|
|
|
<text class="set-text">设置</text>
|
|
|
|
|
|
<uni-icons type="forward" size="14" color="#666"></uni-icons>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
|
2026-01-19 16:52:24 +08:00
|
|
|
|
<!-- 商品列表 -->
|
|
|
|
|
|
<scroll-view class="goods-list" scroll-y="true">
|
|
|
|
|
|
<view class="goods-item" v-for="item in goodsList" :key="item.id">
|
|
|
|
|
|
<view class="goods-more-icon" @tap="toggleDeleteMenu(item)">
|
|
|
|
|
|
<uni-icons type="more-filled" size="18"></uni-icons>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
<view class="goods-delete-menu" v-if="item.showDeleteMenu" @tap="showDeleteConfirm(item)">
|
|
|
|
|
|
<text class="delete-menu-text">删除商品</text>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
<view class="goods-top" @tap="goToStockDetail(item)">
|
|
|
|
|
|
<view class="goods-tou">
|
2026-03-28 22:33:20 +08:00
|
|
|
|
<image :src="item.mainImage ? apiUrl + item.mainImage : apiUrl + '/static/images/687b6f95b14eff60f4b77147b3726ab2.jpg' "></image>
|
2026-01-19 16:52:24 +08:00
|
|
|
|
</view>
|
|
|
|
|
|
<view class="goods-info">
|
|
|
|
|
|
<text class="goods-name">{{ item.productName }}</text>
|
|
|
|
|
|
<text class="goods-barcode">{{ item.productBarCode }}</text>
|
2026-03-27 00:18:36 +08:00
|
|
|
|
<text class="goods-price">¥{{ item.storePrice ? (item.storePrice * 1).toFixed(2) : '0.00' }}</text>
|
2026-01-19 16:52:24 +08:00
|
|
|
|
</view>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
<view class="goods-divider"></view>
|
|
|
|
|
|
<view class="goods-stock" >
|
|
|
|
|
|
<text class="stock-label">总库存</text>
|
|
|
|
|
|
<text class="stock-num">{{ item.stockQuantity }} 件</text>
|
|
|
|
|
|
<text class="stock-arrow">></text>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
</scroll-view>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- 底部操作按钮 -->
|
|
|
|
|
|
<view class="bottom-actions">
|
2026-01-22 14:50:26 +08:00
|
|
|
|
<view class="action-btn more-btn" @tap="showMoreActions()">
|
|
|
|
|
|
<text>更多</text>
|
2026-01-19 16:52:24 +08:00
|
|
|
|
</view>
|
|
|
|
|
|
<button class="action-button primary" @tap="addNewGoods">
|
|
|
|
|
|
添加商品/库存
|
|
|
|
|
|
</button>
|
2026-02-04 20:59:33 +08:00
|
|
|
|
|
2026-01-19 16:52:24 +08:00
|
|
|
|
</view>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- 更多操作弹窗 -->
|
|
|
|
|
|
<uni-popup ref="popup" type="bottom">
|
|
|
|
|
|
<view class="popup-content">
|
2026-01-22 14:50:26 +08:00
|
|
|
|
<view class="popup-item" @tap="goToInventoryCount">
|
|
|
|
|
|
<uni-icons type="scan" size="20" color="#333"></uni-icons>
|
|
|
|
|
|
<text>盘点库存</text>
|
2026-01-19 16:52:24 +08:00
|
|
|
|
</view>
|
2026-01-22 14:50:26 +08:00
|
|
|
|
<view class="popup-item" @tap="goToOutbound">
|
|
|
|
|
|
<uni-icons type="arrowright" size="20" color="#333"></uni-icons>
|
|
|
|
|
|
<text>出库</text>
|
2026-01-19 16:52:24 +08:00
|
|
|
|
</view>
|
2026-01-22 14:50:26 +08:00
|
|
|
|
<view class="popup-item" @tap="batchDeleteGoods">
|
|
|
|
|
|
<uni-icons type="trash" size="20" color="#333"></uni-icons>
|
|
|
|
|
|
<text>批量删除商品</text>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
<view class="popup-item" @tap="goToCategoryManagement">
|
|
|
|
|
|
<uni-icons type="apps" size="20" color="#333"></uni-icons>
|
|
|
|
|
|
<text>分类管理</text>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
<view class="popup-item" @tap="goToBrandManagement">
|
|
|
|
|
|
<uni-icons type="navigate" size="20" color="#333"></uni-icons>
|
|
|
|
|
|
<text>品牌管理</text>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
<view class="popup-item" @tap="goToBarcodeSettings">
|
|
|
|
|
|
<uni-icons type="settings" size="20" color="#333"></uni-icons>
|
|
|
|
|
|
<text>条码规则设置</text>
|
2026-01-19 16:52:24 +08:00
|
|
|
|
</view>
|
|
|
|
|
|
<view class="popup-item cancel" @tap="$refs.popup.close()">
|
|
|
|
|
|
<text>取消</text>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
</uni-popup>
|
|
|
|
|
|
</view>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<script>
|
|
|
|
|
|
import { getProductList as fetchProductList, deleteProduct } from '@/api/product'
|
|
|
|
|
|
import { getToken, getStoreId } from '@/utils/auth'
|
2026-03-28 22:33:20 +08:00
|
|
|
|
import apiUrl from '@/utils/api'
|
2026-01-19 16:52:24 +08:00
|
|
|
|
|
|
|
|
|
|
export default {
|
|
|
|
|
|
data() {
|
|
|
|
|
|
return {
|
2026-03-28 22:33:20 +08:00
|
|
|
|
apiUrl: apiUrl,
|
2026-01-19 16:52:24 +08:00
|
|
|
|
currentTab: 'all',
|
|
|
|
|
|
searchText: '',
|
|
|
|
|
|
showFilter: false,
|
|
|
|
|
|
selectedGoods: null,
|
|
|
|
|
|
storeId: null, // 门店ID
|
|
|
|
|
|
goodsList: [
|
|
|
|
|
|
{
|
|
|
|
|
|
id: null,
|
|
|
|
|
|
productName: '',
|
|
|
|
|
|
productBarCode: '',
|
|
|
|
|
|
storePrice: 0.00,
|
|
|
|
|
|
stockQuantity: 0,
|
|
|
|
|
|
}
|
|
|
|
|
|
]
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
2026-01-19 20:44:58 +08:00
|
|
|
|
onLoad(options) {
|
2026-01-19 16:52:24 +08:00
|
|
|
|
// 获取门店ID
|
|
|
|
|
|
const storeId = getStoreId();
|
|
|
|
|
|
if (storeId) {
|
|
|
|
|
|
this.storeId = storeId;
|
|
|
|
|
|
console.log('当前门店ID:', storeId);
|
|
|
|
|
|
} else {
|
|
|
|
|
|
uni.showToast({
|
|
|
|
|
|
title: '请先选择门店',
|
|
|
|
|
|
icon: 'none'
|
|
|
|
|
|
});
|
|
|
|
|
|
setTimeout(() => {
|
|
|
|
|
|
uni.navigateBack();
|
|
|
|
|
|
}, 1500);
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-01-19 20:44:58 +08:00
|
|
|
|
// 获取传递过来的tab参数
|
|
|
|
|
|
if (options && options.tab) {
|
|
|
|
|
|
this.currentTab = options.tab;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-01-19 16:52:24 +08:00
|
|
|
|
this.getProductList();
|
|
|
|
|
|
},
|
|
|
|
|
|
onShow() {
|
|
|
|
|
|
this.getProductList();
|
|
|
|
|
|
},
|
|
|
|
|
|
methods: {
|
|
|
|
|
|
async getProductList(searchParams = {}) {
|
|
|
|
|
|
try {
|
|
|
|
|
|
const token = getToken();
|
|
|
|
|
|
console.log('当前Token:', token);
|
|
|
|
|
|
console.log('Token是否存在:', !!token);
|
|
|
|
|
|
console.log('查询参数:', searchParams);
|
|
|
|
|
|
|
|
|
|
|
|
// 添加门店ID参数
|
|
|
|
|
|
if (this.storeId) {
|
|
|
|
|
|
searchParams.storeId = this.storeId;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-04 16:55:43 +08:00
|
|
|
|
// 根据标签添加不同的查询参数
|
|
|
|
|
|
if (this.currentTab === 'outstock') {
|
|
|
|
|
|
// 缺货商品
|
|
|
|
|
|
searchParams.stockQuantity = 0;
|
|
|
|
|
|
} else if (this.currentTab === 'expiring') {
|
|
|
|
|
|
// 临期/过期商品
|
|
|
|
|
|
// 这里需要根据实际API添加相应的参数
|
|
|
|
|
|
// 例如:searchParams.expiring = true;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-01-19 16:52:24 +08:00
|
|
|
|
const res = await fetchProductList(searchParams);
|
|
|
|
|
|
|
|
|
|
|
|
console.log('商品列表接口返回:', res);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (res && res.code === 200 && res.data) {
|
|
|
|
|
|
this.goodsList = res.data.map(item => ({
|
|
|
|
|
|
...item,
|
|
|
|
|
|
showDeleteMenu: false
|
|
|
|
|
|
}));
|
|
|
|
|
|
console.log('处理后的商品列表:', this.goodsList);
|
|
|
|
|
|
} else {
|
2026-02-04 16:55:43 +08:00
|
|
|
|
this.goodsList = [];
|
2026-01-19 16:52:24 +08:00
|
|
|
|
uni.showToast({
|
|
|
|
|
|
title: res?.msg || '获取商品列表失败',
|
|
|
|
|
|
icon: 'none'
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
} catch (error) {
|
2026-02-04 16:55:43 +08:00
|
|
|
|
this.goodsList = [];
|
2026-01-19 16:52:24 +08:00
|
|
|
|
console.error('获取商品列表失败:', error);
|
|
|
|
|
|
console.error('错误详情:', JSON.stringify(error));
|
|
|
|
|
|
uni.showToast({
|
|
|
|
|
|
title: '网络请求失败',
|
|
|
|
|
|
icon: 'none'
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
switchTab(tab) {
|
|
|
|
|
|
this.currentTab = tab;
|
2026-02-04 16:55:43 +08:00
|
|
|
|
// 根据标签重新获取商品列表
|
|
|
|
|
|
this.getProductList();
|
2026-01-19 16:52:24 +08:00
|
|
|
|
console.log('切换到标签:', tab);
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
onSearch() {
|
|
|
|
|
|
console.log('搜索关键词:', this.searchText);
|
|
|
|
|
|
|
|
|
|
|
|
if (!this.searchText || this.searchText.trim() === '') {
|
|
|
|
|
|
this.getProductList();
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
const searchText = this.searchText.trim();
|
|
|
|
|
|
let searchParams = {};
|
|
|
|
|
|
|
2026-02-04 16:55:43 +08:00
|
|
|
|
if (/^\d+$/.test(searchText)) {
|
|
|
|
|
|
searchParams = { productBarCode: searchText };
|
|
|
|
|
|
console.log('按条形码精准查询:', searchParams);
|
|
|
|
|
|
} else {
|
|
|
|
|
|
searchParams = { productName: searchText };
|
|
|
|
|
|
console.log('商品名称模糊查询:', searchParams);
|
|
|
|
|
|
}
|
2026-01-19 16:52:24 +08:00
|
|
|
|
|
|
|
|
|
|
this.getProductList(searchParams);
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
goToSettings() {
|
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
|
url: '/pages/settings/index'
|
|
|
|
|
|
});
|
|
|
|
|
|
},
|
|
|
|
|
|
|
2026-02-04 16:55:43 +08:00
|
|
|
|
// 库存不足预警设置
|
|
|
|
|
|
goToAlertSettings() {
|
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
|
url: '/pages/alertSettings/index'
|
|
|
|
|
|
});
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
// 临期促销
|
|
|
|
|
|
goToPromotion() {
|
|
|
|
|
|
console.log('临期促销');
|
|
|
|
|
|
// 这里可以添加临期促销的逻辑
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
// 过期出库
|
|
|
|
|
|
goToExpiredOut() {
|
|
|
|
|
|
console.log('过期出库');
|
|
|
|
|
|
// 这里可以添加过期出库的逻辑
|
|
|
|
|
|
},
|
|
|
|
|
|
|
2026-01-22 14:50:26 +08:00
|
|
|
|
showMoreActions() {
|
2026-01-19 16:52:24 +08:00
|
|
|
|
this.$refs.popup.open();
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
addGoodsStock(goods) {
|
|
|
|
|
|
console.log('添加商品库存:', goods);
|
|
|
|
|
|
uni.showModal({
|
|
|
|
|
|
title: '添加库存',
|
|
|
|
|
|
content: `为 ${goods.name} 添加库存`,
|
|
|
|
|
|
success: (res) => {
|
|
|
|
|
|
if (res.confirm) {
|
|
|
|
|
|
// 执行添加库存操作
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
goToStockDetail(item) {
|
|
|
|
|
|
// 跳转到编辑页面,传递商品ID
|
|
|
|
|
|
uni.navigateTo({
|
2026-03-28 21:37:27 +08:00
|
|
|
|
url: `/package_a/edit/edit?id=${item.id}`
|
2026-01-19 16:52:24 +08:00
|
|
|
|
});
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
toggleDeleteMenu(item) {
|
|
|
|
|
|
item.showDeleteMenu = !item.showDeleteMenu;
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
showDeleteConfirm(item) {
|
|
|
|
|
|
uni.showModal({
|
|
|
|
|
|
title: '确认删除',
|
|
|
|
|
|
content: `确定要删除商品"${item.productName}"吗?`,
|
|
|
|
|
|
success: async (res) => {
|
|
|
|
|
|
if (res.confirm) {
|
|
|
|
|
|
try {
|
|
|
|
|
|
const result = await deleteProduct(item.id);
|
|
|
|
|
|
console.log('删除商品结果:', result);
|
|
|
|
|
|
|
|
|
|
|
|
if (result && result.code === 200) {
|
|
|
|
|
|
uni.showToast({
|
|
|
|
|
|
title: '删除成功',
|
|
|
|
|
|
icon: 'success'
|
|
|
|
|
|
});
|
|
|
|
|
|
// 重新加载商品列表
|
|
|
|
|
|
this.getProductList();
|
|
|
|
|
|
} else {
|
|
|
|
|
|
uni.showToast({
|
|
|
|
|
|
title: result?.msg || '删除失败',
|
|
|
|
|
|
icon: 'none'
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
} catch (error) {
|
|
|
|
|
|
console.error('删除商品失败:', error);
|
|
|
|
|
|
uni.showToast({
|
|
|
|
|
|
title: '删除失败',
|
|
|
|
|
|
icon: 'none'
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
addNewGoods() {
|
2026-03-27 00:18:36 +08:00
|
|
|
|
uni.navigateTo({
|
2026-03-28 21:37:27 +08:00
|
|
|
|
url: '/package_a/translation/translation'
|
2026-03-27 00:18:36 +08:00
|
|
|
|
})
|
|
|
|
|
|
|
2026-01-19 20:44:58 +08:00
|
|
|
|
},
|
2026-01-22 14:50:26 +08:00
|
|
|
|
|
2026-01-19 16:52:24 +08:00
|
|
|
|
batchOperation() {
|
|
|
|
|
|
uni.showActionSheet({
|
|
|
|
|
|
itemList: ['批量修改价格', '批量修改库存', '批量下架'],
|
|
|
|
|
|
success: (res) => {
|
|
|
|
|
|
console.log('选择了操作:', res.tapIndex);
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
editGoods(goods) {
|
|
|
|
|
|
this.$refs.popup.close();
|
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
|
url: `/pages/goods/edit?id=${goods.id}`
|
|
|
|
|
|
});
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
adjustStock(goods) {
|
|
|
|
|
|
this.$refs.popup.close();
|
|
|
|
|
|
uni.showModal({
|
|
|
|
|
|
title: '调整库存',
|
|
|
|
|
|
content: `调整 ${goods.name} 的库存数量`,
|
|
|
|
|
|
editable: true,
|
|
|
|
|
|
placeholderText: '请输入调整数量',
|
|
|
|
|
|
success: (res) => {
|
|
|
|
|
|
if (res.confirm && res.content) {
|
|
|
|
|
|
console.log('调整库存数量:', res.content);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
deleteGoods(goods) {
|
|
|
|
|
|
this.$refs.popup.close();
|
|
|
|
|
|
uni.showModal({
|
|
|
|
|
|
title: '确认删除',
|
|
|
|
|
|
content: `确定要删除商品"${goods.name}"吗?`,
|
|
|
|
|
|
success: (res) => {
|
|
|
|
|
|
if (res.confirm) {
|
|
|
|
|
|
console.log('删除商品:', goods);
|
|
|
|
|
|
uni.showToast({
|
|
|
|
|
|
title: '删除成功',
|
|
|
|
|
|
icon: 'success'
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
2026-01-22 14:50:26 +08:00
|
|
|
|
},
|
|
|
|
|
|
// 盘点库存
|
|
|
|
|
|
goToInventoryCount() {
|
|
|
|
|
|
this.$refs.popup.close();
|
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
|
url: '/pages/inventoryCount/inventoryCount'
|
|
|
|
|
|
});
|
|
|
|
|
|
},
|
|
|
|
|
|
// 出库
|
|
|
|
|
|
goToOutbound() {
|
|
|
|
|
|
this.$refs.popup.close();
|
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
|
url: '/pages/outbound/outbound'
|
|
|
|
|
|
});
|
|
|
|
|
|
},
|
|
|
|
|
|
// 批量删除商品
|
|
|
|
|
|
batchDeleteGoods() {
|
|
|
|
|
|
this.$refs.popup.close();
|
|
|
|
|
|
uni.navigateTo({
|
2026-03-28 21:37:27 +08:00
|
|
|
|
url: '/package_a/batchDeleteProduct/batchDeleteProduct'
|
2026-01-22 14:50:26 +08:00
|
|
|
|
});
|
|
|
|
|
|
},
|
|
|
|
|
|
// 分类管理
|
|
|
|
|
|
goToCategoryManagement() {
|
|
|
|
|
|
this.$refs.popup.close();
|
|
|
|
|
|
uni.navigateTo({
|
2026-03-28 21:37:27 +08:00
|
|
|
|
url: '/package_a/category/category'
|
2026-01-22 14:50:26 +08:00
|
|
|
|
});
|
|
|
|
|
|
},
|
|
|
|
|
|
// 品牌管理
|
|
|
|
|
|
goToBrandManagement() {
|
|
|
|
|
|
this.$refs.popup.close();
|
|
|
|
|
|
uni.navigateTo({
|
2026-03-28 21:37:27 +08:00
|
|
|
|
url: '/package_a/addBrand/addBrand'
|
2026-01-22 14:50:26 +08:00
|
|
|
|
});
|
|
|
|
|
|
},
|
|
|
|
|
|
// 条码规则设置
|
|
|
|
|
|
goToBarcodeSettings() {
|
|
|
|
|
|
this.$refs.popup.close();
|
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
|
url: '/pages/barcodeSettings/barcodeSettings'
|
|
|
|
|
|
});
|
2026-01-19 16:52:24 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
|
|
<style scoped>
|
|
|
|
|
|
.container {
|
|
|
|
|
|
background-color: #f5f5f5;
|
|
|
|
|
|
min-height: 100vh;
|
|
|
|
|
|
}
|
|
|
|
|
|
.goods-tou{
|
|
|
|
|
|
width: 100rpx;
|
|
|
|
|
|
height: 100rpx;
|
|
|
|
|
|
margin-right: 16rpx;
|
|
|
|
|
|
flex-shrink: 0;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.goods-tou image {
|
|
|
|
|
|
width: 100%;
|
|
|
|
|
|
height: 100%;
|
|
|
|
|
|
border-radius: 8rpx;
|
|
|
|
|
|
}
|
|
|
|
|
|
/* 状态栏 */
|
|
|
|
|
|
.status-bar {
|
|
|
|
|
|
padding: 10px 16px;
|
|
|
|
|
|
background-color: #fff;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.time {
|
|
|
|
|
|
font-size: 16px;
|
|
|
|
|
|
font-weight: 600;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* 搜索栏 */
|
|
|
|
|
|
.search-bar {
|
|
|
|
|
|
padding: 12px 16px;
|
|
|
|
|
|
background-color: #fff;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.search-input {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
background-color: #f5f5f5;
|
|
|
|
|
|
border-radius: 8px;
|
|
|
|
|
|
padding: 10px 12px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.search-input input {
|
|
|
|
|
|
flex: 1;
|
|
|
|
|
|
margin-left: 8px;
|
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.placeholder {
|
|
|
|
|
|
color: #999;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* 筛选标签 */
|
|
|
|
|
|
.filter-tabs {
|
|
|
|
|
|
background-color: #fff;
|
|
|
|
|
|
padding: 12px 16px;
|
|
|
|
|
|
border-bottom: 1px solid #eee;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.tabs-scroll {
|
|
|
|
|
|
white-space: nowrap;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.tab-item {
|
|
|
|
|
|
display: inline-block;
|
|
|
|
|
|
padding: 6px 12px;
|
|
|
|
|
|
margin-right: 10px;
|
|
|
|
|
|
border-radius: 16px;
|
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
|
background-color: #f5f5f5;
|
|
|
|
|
|
color: #666;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.tab-item.active {
|
|
|
|
|
|
background-color: #e8f4ff;
|
|
|
|
|
|
color: #007aff;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.badge {
|
|
|
|
|
|
margin-left: 4px;
|
|
|
|
|
|
color: #ff4444;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.filter-btn {
|
|
|
|
|
|
display: inline-flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* 微店状态栏 */
|
|
|
|
|
|
.store-status {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
padding: 12px 16px;
|
|
|
|
|
|
background-color: #fff;
|
|
|
|
|
|
border-radius: 20rpx;
|
|
|
|
|
|
margin-top: 8px;
|
|
|
|
|
|
border-bottom: 1px solid #eee;
|
|
|
|
|
|
}
|
2026-02-04 16:55:43 +08:00
|
|
|
|
|
2026-01-19 16:52:24 +08:00
|
|
|
|
.status-content {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
}
|
2026-02-04 16:55:43 +08:00
|
|
|
|
|
|
|
|
|
|
.status-left-content {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.status-right-buttons {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
gap: 12rpx;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-01-19 16:52:24 +08:00
|
|
|
|
.dui {
|
|
|
|
|
|
margin-right: 12rpx;
|
|
|
|
|
|
}
|
2026-02-04 16:55:43 +08:00
|
|
|
|
|
2026-01-19 16:52:24 +08:00
|
|
|
|
.dui-img {
|
|
|
|
|
|
width: 24rpx;
|
|
|
|
|
|
height: 24rpx;
|
|
|
|
|
|
}
|
2026-02-04 16:55:43 +08:00
|
|
|
|
|
2026-01-19 16:52:24 +08:00
|
|
|
|
.status-left {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
flex-direction: column;
|
|
|
|
|
|
margin-left: 0;
|
|
|
|
|
|
}
|
2026-02-04 16:55:43 +08:00
|
|
|
|
|
2026-01-19 16:52:24 +08:00
|
|
|
|
.status-text {
|
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
|
color: #333;
|
|
|
|
|
|
}
|
2026-02-04 16:55:43 +08:00
|
|
|
|
|
2026-01-19 16:52:24 +08:00
|
|
|
|
.status-num {
|
|
|
|
|
|
font-size: 12px;
|
|
|
|
|
|
color: #666;
|
|
|
|
|
|
margin-top: 4px;
|
|
|
|
|
|
}
|
2026-02-04 16:55:43 +08:00
|
|
|
|
|
2026-01-19 16:52:24 +08:00
|
|
|
|
.status-right {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
margin-right: 1rpx;
|
|
|
|
|
|
}
|
2026-02-04 16:55:43 +08:00
|
|
|
|
|
2026-01-19 16:52:24 +08:00
|
|
|
|
.set-text {
|
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
|
color: #666;
|
|
|
|
|
|
margin-right: 4px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-04 16:55:43 +08:00
|
|
|
|
/* 右侧粉色按钮通用样式 */
|
|
|
|
|
|
.quick-btn {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
background: red;
|
|
|
|
|
|
padding: 8rpx 16rpx;
|
|
|
|
|
|
border-radius: 20rpx;
|
|
|
|
|
|
color: white;
|
|
|
|
|
|
font-size: 22rpx;
|
|
|
|
|
|
gap: 4rpx;
|
|
|
|
|
|
flex-shrink: 0;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.btn-text {
|
|
|
|
|
|
font-size: 22rpx;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-01-19 16:52:24 +08:00
|
|
|
|
/* 商品列表 */
|
|
|
|
|
|
.goods-list {
|
|
|
|
|
|
height: calc(100vh - 320px);
|
|
|
|
|
|
padding: 16px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.goods-item {
|
|
|
|
|
|
background-color: #fff;
|
|
|
|
|
|
border-radius: 8px;
|
|
|
|
|
|
padding: 16px;
|
|
|
|
|
|
margin-bottom: 12px;
|
|
|
|
|
|
box-shadow: 0 2px 4px rgba(0,0,0,0.05);
|
|
|
|
|
|
position: relative;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.goods-more-icon {
|
|
|
|
|
|
position: absolute;
|
|
|
|
|
|
top: 12px;
|
|
|
|
|
|
right: 12px;
|
|
|
|
|
|
z-index: 10;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.goods-delete-menu {
|
|
|
|
|
|
position: absolute;
|
|
|
|
|
|
top: 40px;
|
|
|
|
|
|
right: 12px;
|
|
|
|
|
|
background-color: #fff;
|
|
|
|
|
|
border-radius: 8rpx;
|
|
|
|
|
|
box-shadow: 0 4rpx 12rpx rgba(0, 0, 0, 0.15);
|
|
|
|
|
|
padding: 12rpx 24rpx;
|
|
|
|
|
|
z-index: 9;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.delete-menu-text {
|
|
|
|
|
|
font-size: 28rpx;
|
|
|
|
|
|
color: #ff4444;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.goods-top {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: flex-start;
|
|
|
|
|
|
margin-bottom: 12px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.goods-info {
|
|
|
|
|
|
flex: 1;
|
|
|
|
|
|
margin-bottom: 0;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.goods-name {
|
|
|
|
|
|
display: block;
|
|
|
|
|
|
font-size: 16px;
|
|
|
|
|
|
font-weight: 500;
|
|
|
|
|
|
color: #333;
|
|
|
|
|
|
margin-bottom: 6px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.goods-barcode {
|
|
|
|
|
|
font-size: 12px;
|
|
|
|
|
|
color: #999;
|
|
|
|
|
|
display: block;
|
|
|
|
|
|
margin-bottom: 8px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.goods-price {
|
|
|
|
|
|
font-size: 18px;
|
|
|
|
|
|
color: #ff4444;
|
|
|
|
|
|
font-weight: 600;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.goods-divider {
|
|
|
|
|
|
height: 1px;
|
|
|
|
|
|
border-bottom: 1px dashed #e0e0e0;
|
|
|
|
|
|
margin-bottom: 12px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.goods-stock {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
padding: 8px 0;
|
|
|
|
|
|
margin-bottom: 4px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.stock-arrow {
|
|
|
|
|
|
font-size: 20px;
|
|
|
|
|
|
color: #999;
|
|
|
|
|
|
margin-left: auto;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.stock-label {
|
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
|
color: #666;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.stock-num {
|
|
|
|
|
|
font-size: 16px;
|
|
|
|
|
|
color: #333;
|
|
|
|
|
|
font-weight: 500;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.goods-actions {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.action-btn {
|
|
|
|
|
|
padding: 8px 16px;
|
|
|
|
|
|
border-radius: 6px;
|
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
justify-content: center;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.more-btn {
|
|
|
|
|
|
background-color: #f5f5f5;
|
|
|
|
|
|
color: #666;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.add-btn {
|
|
|
|
|
|
background-color: #e8f4ff;
|
|
|
|
|
|
color: #007aff;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* 底部操作按钮 */
|
|
|
|
|
|
.bottom-actions {
|
|
|
|
|
|
position: fixed;
|
|
|
|
|
|
bottom: 0;
|
|
|
|
|
|
left: 0;
|
|
|
|
|
|
right: 0;
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
padding: 16px;
|
|
|
|
|
|
background-color: #fff;
|
|
|
|
|
|
border-top: 1px solid #eee;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.action-button {
|
|
|
|
|
|
flex: 1;
|
|
|
|
|
|
margin: 0 8px;
|
|
|
|
|
|
padding: 12px;
|
|
|
|
|
|
border-radius: 8px;
|
|
|
|
|
|
font-size: 16px;
|
|
|
|
|
|
background-color: #f5f5f5;
|
|
|
|
|
|
color: #333;
|
|
|
|
|
|
border: none;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.action-button.primary {
|
|
|
|
|
|
background-color: #007aff;
|
|
|
|
|
|
color: #fff;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* 弹窗样式 */
|
|
|
|
|
|
.popup-content {
|
|
|
|
|
|
background-color: #fff;
|
|
|
|
|
|
border-radius: 16px 16px 0 0;
|
|
|
|
|
|
padding: 20px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.popup-item {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
padding: 16px 0;
|
|
|
|
|
|
border-bottom: 1px solid #f5f5f5;
|
|
|
|
|
|
font-size: 16px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.popup-item:last-child {
|
|
|
|
|
|
border-bottom: none;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.popup-item text {
|
|
|
|
|
|
margin-left: 12px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.popup-item.cancel {
|
|
|
|
|
|
justify-content: center;
|
|
|
|
|
|
color: #666;
|
|
|
|
|
|
}
|
|
|
|
|
|
</style>
|