首页细节调整

This commit is contained in:
2026-02-06 16:18:04 +08:00
parent d00f0b7412
commit 57846534bc
86 changed files with 2751 additions and 3074 deletions

View File

@@ -502,7 +502,7 @@ right: 0;
top: 0;
bottom: 0;
width: 50%;
background-color: #fff;
transform: translateX(100%);
transition: transform 0.3s ease-in-out;
display: flex;
@@ -659,4 +659,3 @@ border: none;
.flex-2 { flex: 2; }
.flex-3 { flex: 3; }
</style>

View File

@@ -430,7 +430,7 @@ right: 0;
top: 0;
bottom: 0;
width: 50%;
background-color: #fff;
transform: translateX(100%);
transition: transform 0.3s ease-in-out;
display: flex;
@@ -502,4 +502,3 @@ margin-left: 12px;
.flex-2 { flex: 2; }
.flex-3 { flex: 3; }
</style>

View File

@@ -1,15 +1,15 @@
<template>
<template>
<view class="page-container">
<view class="page-header">
<text class="page-title">鍟嗗搧绠$悊</text>
<text class="page-title">商品管理</text>
<text class="page-subtitle">Component: ProductList</text>
</view>
<view class="page-content">
<view class="placeholder-card">
<text class="placeholder-title">椤甸潰鍗犱綅</text>
<text class="placeholder-desc">璇ュ姛鑳芥ā鍧楁鍦ㄥ紑鍙戜腑</text>
<text class="placeholder-info">褰撳墠閲囩敤 CRMEB 璺敱浣撶郴 1:1 鏄犲皠</text>
<text class="placeholder-title">页面占位</text>
<text class="placeholder-desc">该功能模块正在开发中</text>
<text class="placeholder-info">当前采用 CRMEB 路由体系 1:1 映射</text>
</view>
</view>
</view>
@@ -18,14 +18,14 @@
<script setup lang="uts">
import { ref } from 'vue'
// TODO: 瀹炵幇 鍟嗗搧绠$悊 鐨勫叿浣撳姛鑳?
// TODO: 实现 商品管理 的具体功能
const loading = ref<boolean>(false)
</script>
<style scoped lang="scss">
.page-container {
/* padding removed */
padding: 20px;
min-height: 100vh;
background: #f5f5f5;
}
@@ -79,5 +79,3 @@ const loading = ref<boolean>(false)
color: #1890ff;
}
</style>

View File

@@ -264,7 +264,7 @@ right: 0;
top: 0;
bottom: 0;
width: 50%;
background-color: #fff;
transform: translateX(100%);
transition: transform 0.3s ease-in-out;
display: flex;
@@ -332,4 +332,3 @@ display: flex; flex-direction: row; justify-content: flex-end;
.flex-3 { flex: 3; }
.flex-5 { flex: 5; }
</style>

View File

@@ -1,14 +1,14 @@
<template>
<template>
<view class="product-edit-page">
<view class="page-header">
<view class="back-link" @click="goBack">
<text class="arrow">{"<"}</text>
<text class="back-txt">杩斿洖</text>
<text class="back-txt">返回</text>
</view>
<text class="header-title">缂栬緫鍟嗗搧</text>
<text class="header-title">编辑商品</text>
</view>
<!-- 姝ラ灞?-->
<!-- 步骤层 -->
<view class="steps-card">
<view class="step-items">
<view v-for="(step, index) in steps" :key="index" class="step-item" :class="{ active: activeStep === index }">
@@ -18,17 +18,17 @@
</view>
</view>
<!-- 琛ㄥ崟鍐呭 -->
<!-- 表单内容 -->
<view class="form-card">
<view class="form-item">
<view class="label"><text class="required">*</text><text>鍟嗗搧绫诲瀷锛?/text></view>
<view class="label"><text class="required">*</text><text>商品类型:</text></view>
<view class="input-wrap">
<view class="radio-group">
<view class="radio-item active">
<text class="radio-circle on"></text>
<view class="radio-txt">
<text class="main">鏅€氬晢鍝?/text>
<text class="sub">(鐗╂祦鍙戣揣)</text>
<text class="main">普通商品</text>
<text class="sub">(物流发货)</text>
</view>
</view>
</view>
@@ -36,82 +36,82 @@
</view>
<view class="form-item">
<view class="label"><text class="required">*</text><text>鍟嗗搧鍚嶇О锛?/text></view>
<view class="label"><text class="required">*</text><text>商品名称:</text></view>
<view class="input-wrap">
<view class="input-box">
<input class="real-input" value="UR2024澶忓鏂版濂宠澶嶅彜绾姘涘洿鎰熶竴瀛楄偐鐭T鎭よUWG440060" />
<input class="real-input" value="UR2024夏季新款女装复古纯欲氛围感一字肩短款T恤衫UWG440060" />
<text class="count">36/80</text>
</view>
</view>
</view>
<view class="form-item">
<view class="label"><text class="required">*</text><text>鍗曚綅锛?/text></view>
<view class="label"><text class="required">*</text><text>单位:</text></view>
<view class="input-wrap">
<view class="input-box small">
<input class="real-input" value="浠? />
<input class="real-input" value="件" />
<text class="count">1/5</text>
</view>
</view>
</view>
<view class="form-item">
<view class="label"><text class="required">*</text><text>鍟嗗搧杞挱鍥撅細</text></view>
<view class="label"><text class="required">*</text><text>商品轮播图:</text></view>
<view class="input-wrap">
<view class="image-uploader">
<view v-for="(img, i) in carouselImages" :key="i" class="img-item">
<image :src="img" mode="aspectFill" />
<view class="img-close"></view>
<view class="img-close">×</view>
</view>
<view class="upload-btn">
<text class="icon">+</text>
</view>
</view>
<text class="tip">寤鸿灏哄锛?00*800锛屽彲鎷栨嫿鏀瑰彉鍥剧墖椤哄簭锛岄粯璁ら寮犲浘涓轰富鍥撅紝鏈€澶氫笂浼?0寮?/text>
<text class="tip">建议尺寸800*800可拖拽改变图片顺序默认首张图为主图最多上传10张</text>
</view>
</view>
<view class="form-item">
<view class="label"><text>娣诲姞瑙嗛锛?/text></view>
<view class="label"><text>添加视频:</text></view>
<view class="input-wrap">
<view class="upload-btn v-btn">
<text class="v-icon">馃摴</text>
<text class="v-icon">📹</text>
</view>
<text class="tip">寤鸿鏃堕暱锛?~30绉掞紝瑙嗛瀹介珮姣?6:9</text>
<text class="tip">建议时长9~30秒视频宽高比16:9</text>
</view>
</view>
<view class="form-item">
<view class="label"><text class="required">*</text><text>鍟嗗搧鍒嗙被锛?/text></view>
<view class="label"><text class="required">*</text><text>商品分类:</text></view>
<view class="input-wrap">
<view class="tag-selector">
<view v-for="tag in categories" :key="tag" class="tag-item">
<text>{{ tag }}</text>
<text class="close"></text>
<text class="close">×</text>
</view>
<text class="add-link">鏂板鍒嗙被</text>
<text class="add-link">新增分类</text>
</view>
</view>
</view>
<view class="form-item">
<view class="label"><text>鍟嗗搧鏍囩锛?/text></view>
<view class="label"><text>商品标签:</text></view>
<view class="input-wrap">
<view class="mock-btn-select">閫夋嫨鏍囩</view>
<view class="mock-btn-select">选择标签</view>
</view>
</view>
<view class="form-item">
<view class="label"><text>鍟嗗搧鐘舵€侊細</text></view>
<view class="label"><text>商品状态:</text></view>
<view class="input-wrap">
<view class="radio-group-simple">
<view class="radio-simple on">
<text class="dot"></text>
<text>涓婃灦</text>
<text>上架</text>
</view>
<view class="radio-simple">
<text class="dot"></text>
<text>涓嬫灦</text>
<text>下架</text>
</view>
</view>
</view>
@@ -119,8 +119,8 @@
</view>
<view class="footer-btns">
<button class="btn-next">涓嬩竴姝?/button>
<button class="btn-save">淇濆瓨</button>
<button class="btn-next">下一步</button>
<button class="btn-save">保存</button>
</view>
</view>
</template>
@@ -130,7 +130,7 @@ import { ref } from 'vue'
import { openRoute } from '@/layouts/admin/store/adminNavStore.uts'
const activeStep = ref(0)
const steps = ['鍩虹淇℃伅', '瑙勬牸搴撳瓨', '鍟嗗搧璇︽儏', '鐗╂祦璁剧疆', '浼氬憳浠?浣i噾', '钀ラ攢璁剧疆', '鍏朵粬璁剧疆']
const steps = ['基础信息', '规格库存', '商品详情', '物流设置', '会员价/佣金', '营销设置', '其他设置']
const carouselImages = ref([
'https://img1.baidu.com/it/u=254065646,3100346083&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500',
@@ -138,7 +138,7 @@ const carouselImages = ref([
'https://img2.baidu.com/it/u=3775079632,546700868&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500'
])
const categories = ref(['鐢熸椿瀹跺眳', '杩愬姩涓撳尯 / 361', '杩愬姩涓撳尯 / 鐗规', '杩愬姩涓撳尯 / 鍖瑰厠'])
const categories = ref(['生活家居', '运动专区 / 361', '运动专区 / 特步', '运动专区 / 匹克'])
function goBack() {
openRoute('product_productList')
@@ -147,9 +147,9 @@ function goBack() {
<style scoped lang="scss">
.product-edit-page {
/* padding removed */
padding: 20px;
background-color: #f5f7f9;
min-height: 100vh;
}
.page-header {
@@ -249,7 +249,7 @@ function goBack() {
.sub { font-size: 12px; color: #999; }
}
&::after {
content: '鉁?;
content: '✓';
position: absolute;
right: 0; bottom: 0;
background: #1890ff; color: #fff; font-size: 10px; padding: 0 2px;
@@ -345,4 +345,3 @@ function goBack() {
.btn-save { background: #fff; color: #1890ff; border: 1px solid #1890ff; padding: 0 24px; height: 40px; border-radius: 4px; }
}
</style>

View File

@@ -1,47 +1,47 @@
<template>
<template>
<view class="product-list-page">
<!-- 1. 鎼滅储琛ㄥ崟 -->
<!-- 1. 搜索表单 -->
<view class="search-card">
<view class="search-row">
<view class="search-item">
<text class="label">鍟嗗搧鎼滅储锛?/text>
<input class="mock-input" placeholder="璇疯緭鍏ュ晢鍝佸悕绉?鍏抽敭瀛?ID" />
<text class="label">商品搜索:</text>
<input class="mock-input" placeholder="请输入商品名称/关键字/ID" />
</view>
<view class="search-item">
<text class="label">鍟嗗搧绫诲瀷锛?/text>
<text class="label">商品类型:</text>
<view class="mock-select">
<text>鍏ㄩ儴</text>
<text class="arrow">鈻?/text>
<text>全部</text>
<text class="arrow">▼</text>
</view>
</view>
<view class="search-item">
<text class="label">鍟嗗搧鍒嗙被锛?/text>
<text class="label">商品分类:</text>
<view class="mock-select">
<text>璇烽€夋嫨</text>
<text class="arrow">鈻?/text>
<text>请选择</text>
<text class="arrow">▼</text>
</view>
</view>
<view class="search-btns">
<button class="btn-primary">鏌ヨ</button>
<button class="btn-reset">閲嶇疆</button>
<button class="btn-primary">查询</button>
<button class="btn-reset">重置</button>
<view class="expand-control">
<text class="expand-txt">灞曞紑</text>
<text class="expand-arrow">鈻?/text>
<text class="expand-txt">展开</text>
<text class="expand-arrow">▼</text>
</view>
</view>
</view>
<view class="search-row mt-12">
<view class="search-item">
<text class="label">閰嶉€佹柟寮忥細</text>
<text class="label">配送方式:</text>
<view class="mock-select">
<text>鍏ㄩ儴</text>
<text class="arrow">鈻?/text>
<text>全部</text>
<text class="arrow">▼</text>
</view>
</view>
</view>
</view>
<!-- 2. 鍟嗗搧鐘舵€?Tabs -->
<!-- 2. 商品状态 Tabs -->
<view class="status-tabs-wrap">
<view class="status-tabs">
<view
@@ -56,46 +56,46 @@
</view>
</view>
<!-- 3. 鎿嶄綔鎸夐挳琛?-->
<!-- 3. 操作按钮行 -->
<view class="action-bar">
<view class="left-actions">
<button class="btn-add" @click="goEdit(null)">娣诲姞鍟嗗搧</button>
<button class="btn-collect">鍟嗗搧閲囬泦</button>
<button class="btn-add" @click="goEdit(null)">添加商品</button>
<button class="btn-collect">商品采集</button>
<view class="btn-dropdown">
<text>鎵归噺淇敼</text>
<text class="arrow">鈻?/text>
<text>批量修改</text>
<text class="arrow">▼</text>
</view>
<view class="btn-dropdown">
<text>鍟嗗搧杩佺Щ</text>
<text class="arrow">鈻?/text>
<text>商品迁移</text>
<text class="arrow">▼</text>
</view>
<button class="btn-export">鏁版嵁瀵煎嚭</button>
<button class="btn-export">数据导出</button>
</view>
</view>
<!-- 4. 鍟嗗搧鍒楄〃琛ㄦ牸 -->
<!-- 4. 商品列表表格 -->
<view class="list-card">
<view class="table-v5">
<view class="th-row">
<view class="th col-check"><text>鈻?/text></view>
<view class="th col-id"><text>鍟嗗搧ID</text></view>
<view class="th col-img"><text>鍟嗗搧鍥?/text></view>
<view class="th col-name"><text>鍟嗗搧鍚嶇О</text></view>
<view class="th col-activity"><text>鍙備笌娲诲姩</text></view>
<view class="th col-type"><text>鍟嗗搧绫诲瀷</text></view>
<view class="th col-price"><text>鍟嗗搧鍞环</text></view>
<view class="th col-sales"><text>閿€閲?/text></view>
<view class="th col-stock"><text>搴撳瓨</text></view>
<view class="th col-sort"><text>鎺掑簭</text></view>
<view class="th col-status"><text>鐘舵€?/text></view>
<view class="th col-op"><text>鎿嶄綔</text></view>
<view class="th col-check"><text>□</text></view>
<view class="th col-id"><text>商品ID</text></view>
<view class="th col-img"><text>商品图</text></view>
<view class="th col-name"><text>商品名称</text></view>
<view class="th col-activity"><text>参与活动</text></view>
<view class="th col-type"><text>商品类型</text></view>
<view class="th col-price"><text>商品售价</text></view>
<view class="th col-sales"><text>销量</text></view>
<view class="th col-stock"><text>库存</text></view>
<view class="th col-sort"><text>排序</text></view>
<view class="th col-status"><text>状态</text></view>
<view class="th col-op"><text>操作</text></view>
</view>
<view v-for="(item, index) in productList" :key="index"
class="tr-row"
:style="{ zIndex: activeDropdownId === item.id ? 1000 : 1 }"
>
<view class="td col-check"><text>鈻?/text></view>
<view class="td col-check"><text>□</text></view>
<view class="td col-id"><text>{{ item.id }}</text></view>
<view class="td col-img">
<image class="p-img" :src="item.image" mode="aspectFill" />
@@ -116,28 +116,28 @@
<view class="td col-sort"><text>{{ item.sort }}</text></view>
<view class="td col-status">
<view class="mock-switch" :class="{ on: item.status === 1 }">
<text class="switch-txt">{{ item.status === 1 ? '涓婃灦' : '涓嬫灦' }}</text>
<text class="switch-txt">{{ item.status === 1 ? '上架' : '下架' }}</text>
<view class="switch-dot"></view>
</view>
</view>
<view class="td col-op op-group">
<text class="op-link" @click.stop="goEdit(item.id)">缂栬緫</text>
<text class="op-link" @click.stop="goEdit(item.id)">编辑</text>
<text class="op-divider">|</text>
<view class="more-hover-box"
@mouseenter="activeDropdownId = item.id"
@mouseleave="activeDropdownId = null"
>
<view class="more-trigger-txt">
<text class="more-link-text">鏇村</text>
<text class="more-arrow-icon">鈭?/text>
<text class="more-link-text">更多</text>
<text class="more-arrow-icon"></text>
</view>
<view class="dropdown-list-container" v-show="activeDropdownId === item.id">
<view class="dropdown-triangle"></view>
<view class="dropdown-menu-body">
<text class="menu-item" @click.stop="goReviews(item.id)">鏌ョ湅璇勮</text>
<text class="menu-item" @click.stop="goMemberPrice(item.id)">浼氬憳浠风鐞?/text>
<text class="menu-item" @click.stop="uni.showToast({title:'浣i噾绠$悊寮€鍙戜腑', icon:'none'})">浣i噾绠$悊</text>
<text class="menu-item danger-item" @click.stop="moveToRecycle(item.id)">{{ activeStatus === 'recycle' ? '鎭㈠鍟嗗搧' : '绉诲埌鍥炴敹绔? }}</text>
<text class="menu-item" @click.stop="goReviews(item.id)">查看评论</text>
<text class="menu-item" @click.stop="goMemberPrice(item.id)">会员价管理</text>
<text class="menu-item" @click.stop="uni.showToast({title:'佣金管理开发中', icon:'none'})">佣金管理</text>
<text class="menu-item danger-item" @click.stop="moveToRecycle(item.id)">{{ activeStatus === 'recycle' ? '恢复商品' : '移到回收站' }}</text>
</view>
</view>
</view>
@@ -145,9 +145,9 @@
</view>
</view>
<!-- 5. 鍒嗛〉 -->
<!-- 5. 分页 -->
<view class="pagination-row">
<text class="total">鍏?{{ total }} 鏉?/text>
<text class="total">{{ total }} 条</text>
<view class="page-ctrl">
<text class="page-btn disabled">{"<"}</text>
<text class="page-num active">1</text>
@@ -168,20 +168,20 @@ const activeStatus = ref('selling')
const activeDropdownId = ref<number | null>(null)
const statusTabs = ref([
{ key: 'selling', label: '鍑哄敭涓殑鍟嗗搧', count: 49 },
{ key: 'warehouse', label: '浠撳簱涓殑鍟嗗搧', count: 4 },
{ key: 'soldout', label: '宸茬粡鍞絼鍟嗗搧', count: 11 },
{ key: 'alarm', label: '璀︽垝搴撳瓨鍟嗗搧', count: 27 },
{ key: 'recycle', label: '鍥炴敹绔欑殑鍟嗗搧', count: 176 },
{ key: 'selling', label: '出售中的商品', count: 49 },
{ key: 'warehouse', label: '仓库中的商品', count: 4 },
{ key: 'soldout', label: '已经售罄商品', count: 11 },
{ key: 'alarm', label: '警戒库存商品', count: 27 },
{ key: 'recycle', label: '回收站的商品', count: 176 },
])
const productList = ref([
{
id: 963,
image: 'https://img1.baidu.com/it/u=254065646,3100346083&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500',
name: 'UR2024澶忓鏂版濂宠澶嶅彜绾姘涘洿鎰熶竴瀛楄偐鐭T鎭よUWG440060',
name: 'UR2024夏季新款女装复古纯欲氛围感一字肩短款T恤衫UWG440060',
activities: ['kj', 'pt'],
typeName: '鏅€氬晢鍝?,
typeName: '普通商品',
price: '0.01',
sales: 639,
stock: 1602,
@@ -191,9 +191,9 @@ const productList = ref([
{
id: 108,
image: 'https://img2.baidu.com/it/u=3033501986,2204481084&fm=253&fmt=auto&app=138&f=JPEG?w=569&h=500',
name: 'FOMIX 铔嬪3妞?杩涘彛澶村眰鐗涚毊姗欒壊鍗曚汉娌欏彂妞匛gg chair璁捐甯堝笀鍗曟鍗曟矙澶村眰鐗涚毊/鍗曟',
name: 'FOMIX 蛋壳椅 进口头层牛皮橙色单人沙发椅Egg chair设计师师单椅单沙头层牛皮/单椅',
activities: ['pt', 'ms'],
typeName: '鏅€氬晢鍝?,
typeName: '普通商品',
price: '7580.00',
sales: 14,
stock: 16638,
@@ -203,9 +203,9 @@ const productList = ref([
{
id: 48,
image: 'https://img0.baidu.com/it/u=1762118431,3101886131&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500',
name: '闃胯开杈炬柉瀹樼綉 adidas BBALL CAP COT 鐢峰コ璁粌杩愬姩甯藉瓙FQ5270 浼犲澧ㄦ按钃?浼犲澧ㄦ按钃?鐧?XL',
name: '阿迪达斯官网 adidas BBALL CAP COT 男女训练运动帽子FQ5270 传奇墨水蓝/传奇墨水蓝/白 XL',
activities: ['kj', 'pt', 'ms'],
typeName: '鏅€氬晢鍝?,
typeName: '普通商品',
price: '100.00',
sales: 841,
stock: 2318,
@@ -215,9 +215,9 @@ const productList = ref([
])
function getActivityName(tag: string): string {
if (tag === 'kj') return '鐮嶄环'
if (tag === 'pt') return '鎷煎洟'
if (tag === 'ms') return '绉掓潃'
if (tag === 'kj') return '砍价'
if (tag === 'pt') return '拼团'
if (tag === 'ms') return '秒杀'
return tag
}
@@ -234,13 +234,13 @@ function goMemberPrice(id: number) {
}
function moveToRecycle(id: number) {
const action = activeStatus.value === 'recycle' ? '鎭㈠' : '绉诲埌鍥炴敹绔?;
const action = activeStatus.value === 'recycle' ? '恢复' : '移到回收站';
uni.showModal({
title: '鎻愮ず',
content: `纭瑕佸皢璇ュ晢鍝?{action}鍚楋紵`,
title: '提示',
content: `确认要将该商品${action}吗?`,
success: (res) => {
if (res.confirm) {
uni.showToast({ title: '鎿嶄綔鎴愬姛', icon: 'success' });
uni.showToast({ title: '操作成功', icon: 'success' });
}
}
})
@@ -249,9 +249,9 @@ function moveToRecycle(id: number) {
<style scoped lang="scss">
.product-list-page {
/* padding removed */
padding: 20px;
background-color: #f5f7f9;
min-height: 100vh;
}
.search-card {
@@ -457,7 +457,7 @@ function moveToRecycle(id: number) {
display: flex;
flex-direction: row;
align-items: center;
pointer-events: none; /* 璁╀簨浠堕€忎紶缁?more-hover-box */
pointer-events: none; /* 让事件透传给 more-hover-box */
}
.more-link-text {
@@ -476,7 +476,7 @@ function moveToRecycle(id: number) {
top: 35px;
right: -10px;
width: 120px;
padding-top: 8px; /* 澧炲姞鎰熷簲杩炵画鎬?*/
padding-top: 8px; /* 增加感应连续性 */
z-index: 9999;
}
@@ -614,4 +614,3 @@ function moveToRecycle(id: number) {
}
}
</style>

View File

@@ -1,30 +1,30 @@
<template>
<template>
<view class="member-price-page">
<view class="page-header">
<view class="back-link" @click="goBack">
<text class="arrow">{"<"}</text>
<text class="back-txt">杩斿洖</text>
<text class="back-txt">返回</text>
</view>
<text class="header-title">浼氬憳浠风鐞?/text>
<text class="header-title">会员价管理</text>
</view>
<view class="content-card">
<view class="product-info">
<image class="p-img" src="https://img1.baidu.com/it/u=254065646,3100346083&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500" mode="aspectFill" />
<text class="p-name">UR2024澶忓鏂版濂宠澶嶅彜绾姘涘洿鎰熶竴瀛楄偐鐭T鎭よ</text>
<text class="p-name">UR2024夏季新款女装复古纯欲氛围感一字肩短款T恤衫</text>
</view>
<view class="price-table">
<view class="th-row">
<view class="th flex-2"><text>瑙勬牸鍚嶇О</text></view>
<view class="th flex-1"><text>鍞环</text></view>
<view class="th flex-1"><text>鏅€氫細鍛樹环</text></view>
<view class="th flex-1"><text>榛勯噾浼氬憳浠?/text></view>
<view class="th flex-1"><text>閾傞噾浼氬憳浠?/text></view>
<view class="th flex-2"><text>规格名称</text></view>
<view class="th flex-1"><text>售价</text></view>
<view class="th flex-1"><text>普通会员价</text></view>
<view class="th flex-1"><text>黄金会员价</text></view>
<view class="th flex-1"><text>铂金会员价</text></view>
</view>
<view class="tr-row">
<view class="td flex-2"><text>XL,鍗″叾</text></view>
<view class="td flex-1"><text>锟?9.00</text></view>
<view class="td flex-2"><text>XL,卡其</text></view>
<view class="td flex-1"><text>¥99.00</text></view>
<view class="td flex-1"><input class="price-input" value="89.00" /></view>
<view class="td flex-1"><input class="price-input" value="79.00" /></view>
<view class="td flex-1"><input class="price-input" value="69.00" /></view>
@@ -32,7 +32,7 @@
</view>
<view class="footer-btns">
<button class="btn-save">淇濆瓨璁剧疆</button>
<button class="btn-save">保存设置</button>
</view>
</view>
</view>
@@ -47,7 +47,7 @@ function goBack() {
</script>
<style scoped lang="scss">
.member-price-page { /* padding removed */ background: #f5f7f9; }
.member-price-page { padding: 20px; background: #f5f7f9; min-height: 100vh; }
.page-header { display: flex; flex-direction: row; align-items: center; gap: 16px; margin-bottom: 20px;
.back-link { display: flex; flex-direction: row; align-items: center; gap: 4px; color: #666; cursor: pointer; }
.header-title { font-size: 16px; font-weight: bold; color: #333; }
@@ -66,4 +66,3 @@ function goBack() {
.price-input { border: 1px solid #dcdfe6; border-radius: 4px; height: 32px; padding: 0 8px; text-align: center; width: 80%; font-size: 13px; }
.footer-btns { margin-top: 40px; display: flex; justify-content: center; .btn-save { background: #1890ff; color: #fff; border: none; padding: 0 32px; height: 40px; border-radius: 4px; } }
</style>

View File

@@ -1,22 +1,22 @@
<template>
<template>
<view class="product-statistic-page">
<!-- 鍟嗗搧姒傚喌澶撮儴 -->
<!-- 商品概况头部 -->
<view class="page-header-row">
<view class="title-wrap">
<text class="page-title">鍟嗗搧姒傚喌</text>
<text class="page-title">商品概况</text>
<view class="info-icon">?</view>
</view>
<view class="header-right">
<view class="date-picker-wrap">
<text class="calendar-emoji">馃搮</text>
<text class="calendar-emoji">📅</text>
<text class="date-range">2026/01/04 - 2026/02/02</text>
</view>
<button class="btn-query">鏌ヨ</button>
<button class="btn-export">瀵煎嚭</button>
<button class="btn-query">查询</button>
<button class="btn-export">导出</button>
</view>
</view>
<!-- 缁熻鎸囨爣缃戞牸 (浣跨敤缁熶竴鍝嶅簲寮忕綉鏍? -->
<!-- 统计指标网格 (使用统一响应式网格) -->
<view class="kpi-grid">
<view v-for="(item, index) in statItems" :key="index" class="stat-card">
<view class="stat-main">
@@ -27,11 +27,11 @@
<text class="stat-label">{{ item.label }}</text>
<text class="stat-value">{{ item.value }}</text>
<view class="stat-compare">
<text class="compare-label">鍧忔瘮澧為暱锛?/text>
<text class="compare-label">坏比增长:</text>
<text class="compare-val" :class="item.trendClass">
{{ item.compare }}
<text v-if="item.trend === 'up'" class="arrow">鈻?/text>
<text v-else-if="item.trend === 'down'" class="arrow">鈻?/text>
<text v-if="item.trend === 'up'" class="arrow">▲</text>
<text v-else-if="item.trend === 'down'" class="arrow">▼</text>
<text v-else>-</text>
</text>
</view>
@@ -40,17 +40,17 @@
</view>
</view>
<!-- 鍥捐〃鍗$墖 -->
<!-- 图表卡片 -->
<view class="chart-card">
<view class="chart-header">
<view class="legend-wrap">
<view class="legend-item"><view class="dot purple"></view><text>鍟嗗搧娴忚閲?/text></view>
<view class="legend-item"><view class="dot orange"></view><text>鍟嗗搧璁垮閲?/text></view>
<view class="legend-item"><view class="dot blue"></view><text>鏀粯閲戦</text></view>
<view class="legend-item"><view class="dot green"></view><text>閫€娆鹃噾棰?/text></view>
<view class="legend-item"><view class="dot purple"></view><text>商品浏览量</text></view>
<view class="legend-item"><view class="dot orange"></view><text>商品访客量</text></view>
<view class="legend-item"><view class="dot blue"></view><text>支付金额</text></view>
<view class="legend-item"><view class="dot green"></view><text>退款金额</text></view>
</view>
<view class="download-icon">
<text class="download-emoji">馃摜</text>
<text class="download-emoji">📥</text>
</view>
</view>
<view class="chart-main">
@@ -58,36 +58,36 @@
</view>
</view>
<!-- 鍟嗗搧鎺掕 -->
<!-- 商品排行 -->
<view class="ranking-card">
<view class="ranking-header">
<text class="ranking-title">鍟嗗搧鎺掕</text>
<text class="ranking-title">商品排行</text>
<view class="ranking-filters">
<view class="mock-select-wrap">
<text class="select-val">娴忚閲?/text>
<text class="select-arrow">鈻?/text>
<text class="select-val">浏览量</text>
<text class="select-arrow">▼</text>
</view>
<view class="date-picker-wrap">
<text class="calendar-emoji">馃搮</text>
<text class="calendar-emoji">📅</text>
<text class="date-range">2026/01/04 - 2026/02/02</text>
</view>
<button class="btn-query small">鏌ヨ</button>
<button class="btn-query small">查询</button>
</view>
</view>
<view class="ranking-table">
<view class="table-header">
<text class="th col-id">ID</text>
<text class="th col-img">鍟嗗搧鍥剧墖</text>
<text class="th col-name">鍟嗗搧鍚嶇О</text>
<text class="th col-num">娴忚閲?/text>
<text class="th col-num">璁垮鏁?/text>
<text class="th col-num">鍔犺喘浠舵暟</text>
<text class="th col-num">涓嬪崟浠舵暟</text>
<text class="th col-num">鏀粯浠舵暟</text>
<text class="th col-num">鏀粯閲戦</text>
<text class="th col-num">鏀惰棌鏁?/text>
<text class="th col-num wide">璁垮-鏀粯杞寲鐜?%)</text>
<text class="th col-img">商品图片</text>
<text class="th col-name">商品名称</text>
<text class="th col-num">浏览量</text>
<text class="th col-num">访客数</text>
<text class="th col-num">加购件数</text>
<text class="th col-num">下单件数</text>
<text class="th col-num">支付件数</text>
<text class="th col-num">支付金额</text>
<text class="th col-num">收藏数</text>
<text class="th col-num wide">访客-支付转化率(%)</text>
</view>
<view v-for="(item, index) in rankingList" :key="index" class="table-row">
<text class="td col-id">{{ item.id }}</text>
@@ -116,19 +116,19 @@ import { ref, onMounted } from 'vue'
import EChartsView from '@/uni_modules/charts/EChartsView.vue'
const statItems = ref([
{ label: '鍟嗗搧娴忚閲?, value: '7576', compare: '0.93%', trend: 'up', trendClass: 'up-red', bgColor: '#e6f7ff', emoji: '馃憗锔? },
{ label: '鍟嗗搧璁垮閲?, value: '765', compare: '0.79%', trend: 'up', trendClass: 'up-red', bgColor: '#f6ffed', emoji: '馃懁' },
{ label: '鏀粯浠舵暟', value: '322', compare: '-49.52%', trend: 'down', trendClass: 'down-green', bgColor: '#fff7e6', emoji: '馃泹锔? },
{ label: '鏀粯閲戦', value: '443254.62', compare: '-63.62%', trend: 'down', trendClass: 'down-green', bgColor: '#f9f0ff', emoji: '馃挵' },
{ label: '閫€娆句欢鏁?, value: '0', compare: '0.00%', trend: 'none', trendClass: 'none-gray', bgColor: '#e6f7ff', emoji: '馃攧' },
{ label: '閫€娆鹃噾棰?, value: '0', compare: '0.00%', trend: 'none', trendClass: 'none-gray', bgColor: '#f6ffed', emoji: '馃挻' }
{ label: '商品浏览量', value: '7576', compare: '0.93%', trend: 'up', trendClass: 'up-red', bgColor: '#e6f7ff', emoji: '👁️' },
{ label: '商品访客量', value: '765', compare: '0.79%', trend: 'up', trendClass: 'up-red', bgColor: '#f6ffed', emoji: '👤' },
{ label: '支付件数', value: '322', compare: '-49.52%', trend: 'down', trendClass: 'down-green', bgColor: '#fff7e6', emoji: '🛍️' },
{ label: '支付金额', value: '443254.62', compare: '-63.62%', trend: 'down', trendClass: 'down-green', bgColor: '#f9f0ff', emoji: '💰' },
{ label: '退款件数', value: '0', compare: '0.00%', trend: 'none', trendClass: 'none-gray', bgColor: '#e6f7ff', emoji: '🔄' },
{ label: '退款金额', value: '0', compare: '0.00%', trend: 'none', trendClass: 'none-gray', bgColor: '#f6ffed', emoji: '💴' }
])
const rankingList = ref([
{
id: 963,
image: 'https://img1.baidu.com/it/u=254065646,3100346083&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500',
name: 'UR2024澶忓鏂版濂宠澶嶅彜绾姘涘洿鎰熶竴瀛楄偐鐭T鎭よUWG440060',
name: 'UR2024夏季新款女装复古纯欲氛围感一字肩短款T恤衫UWG440060',
views: 1200,
visitors: 246,
cartCount: 74,
@@ -141,7 +141,7 @@ const rankingList = ref([
{
id: 116,
image: 'https://img2.baidu.com/it/u=3775079632,546700868&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500',
name: '鐖卞鑹烘櫤鑳?濂囬亣LT01 鎶曞奖浠?瀹剁敤鍗у瓒呴珮娓呮墜鏈轰究鎼烘姇褰辨満 (4K瓒呮竻 鏀寔渚ф姇 鎵嬫満鍚屽睆 鍗庝负涓€纰板嵆鎶?',
name: '爱奇艺智能 奇遇LT01 投影仪 家用卧室超高清手机便携投影机 (4K超清 支持侧投 手机同屏 华为一碰即投)',
views: 959,
visitors: 376,
cartCount: 1,
@@ -154,7 +154,7 @@ const rankingList = ref([
{
id: 48,
image: 'https://img0.baidu.com/it/u=1762118431,3101886131&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500',
name: '闃胯开杈炬柉瀹樼綉 adidas BBALL CAP COT 鐢峰コ璁粌杩愬姩甯藉瓙FQ5270 浼犲澧ㄦ按钃?浼犲澧ㄦ按钃?鐧?XL',
name: '阿迪达斯官网 adidas BBALL CAP COT 男女训练运动帽子FQ5270 传奇墨水蓝/传奇墨水蓝/白 XL',
views: 758,
visitors: 207,
cartCount: 63,
@@ -167,7 +167,7 @@ const rankingList = ref([
{
id: 108,
image: 'https://img2.baidu.com/it/u=3033501986,2204481084&fm=253&fmt=auto&app=138&f=JPEG?w=569&h=500',
name: 'FOMIX 铔嬪3妞?杩涘彛澶村眰鐗涚毊姗欒壊鍗曚汉娌欏彂妞匛gg chair璁捐甯堝笀鍗曟鍗曟矙澶村眰鐗涚毊/鍗曟',
name: 'FOMIX 蛋壳椅 进口头层牛皮橙色单人沙发椅Egg chair设计师师单椅单沙头层牛皮/单椅',
views: 730,
visitors: 216,
cartCount: 26999,
@@ -251,14 +251,14 @@ function initChart() {
yAxis: [
{
type: 'value',
name: '閲戦',
name: '金额',
nameTextStyle: { color: '#8c8c8c', padding: [0, 30, 0, 0] },
splitLine: { lineStyle: { type: 'dashed', color: '#f0f0f0' } },
axisLabel: { color: '#8c8c8c' }
},
{
type: 'value',
name: '鏁伴噺',
name: '数量',
nameTextStyle: { color: '#8c8c8c', padding: [0, 0, 0, 30] },
splitLine: { show: false },
axisLabel: { color: '#8c8c8c' }
@@ -266,7 +266,7 @@ function initChart() {
],
series: [
{
name: '鍟嗗搧娴忚閲?,
name: '商品浏览量',
type: 'line',
yAxisIndex: 1,
smooth: true,
@@ -276,7 +276,7 @@ function initChart() {
data: [90, 110, 115, 100, 95, 80, 60, 40, 70, 85, 75, 65, 70, 80, 100, 120, 110, 90, 60, 95, 115, 110, 85, 50, 45, 55, 75]
},
{
name: '鍟嗗搧璁垮閲?,
name: '商品访客量',
type: 'line',
yAxisIndex: 1,
smooth: true,
@@ -286,14 +286,14 @@ function initChart() {
data: [15, 12, 10, 8, 11, 14, 13, 8, 9, 11, 10, 15, 12, 11, 9, 12, 14, 15, 11, 10, 13, 15, 11, 8, 12, 10, 14]
},
{
name: '鏀粯閲戦',
name: '支付金额',
type: 'bar',
barWidth: '25%',
itemStyle: { color: '#1890ff' },
data: [10, 5, 8, 0, 145, 15, 5, 0, 0, 0, 0, 5, 30, 0, 15, 20, 100, 20, 25, 5, 1, 3, 70, 5, 10, 5, 15, 10]
},
{
name: '閫€娆鹃噾棰?,
name: '退款金额',
type: 'bar',
barWidth: '25%',
itemStyle: { color: '#52c41a' },
@@ -315,9 +315,9 @@ function initChart() {
<style scoped lang="scss">
.product-statistic-page {
/* padding removed */
padding: 16px;
background-color: #f0f2f5;
min-height: 100vh;
}
.page-header-row {
@@ -367,7 +367,7 @@ function initChart() {
.btn-query { background: #1890ff; color: #fff; font-size: 14px; height: 32px; padding: 0 15px; border-radius: 4px; border: none; }
.btn-export { background: #1890ff; color: #fff; font-size: 14px; height: 32px; padding: 0 15px; border-radius: 4px; border: none; }
/* stat-grid 宸插簾寮冿紝鐢卞叏灞€ kpi-grid 鎺ョ */
/* stat-grid 已废弃,由全局 kpi-grid 接管 */
.stat-card {
background: #fff;
border-radius: 8px;
@@ -458,7 +458,7 @@ function initChart() {
}
.main-chart { width: 100%; height: 100%; }
/* 鍟嗗搧鎺掕 */
/* 商品排行 */
.ranking-card {
background: #fff;
border-radius: 8px;
@@ -538,7 +538,7 @@ function initChart() {
justify-content: center;
}
/* 鍒楀搴﹂厤缃?*/
/* 列宽度配置 */
.col-id { width: 60px; }
.col-img { width: 100px; }
.col-name { flex: 1; text-align: left; justify-content: flex-start; }
@@ -559,4 +559,3 @@ function initChart() {
}
</style>

View File

@@ -1,62 +1,62 @@
<template>
<template>
<view class="product-reply-page">
<!-- 1. 鎼滅储绛涢€?-->
<!-- 1. 搜索筛选 -->
<view class="search-card">
<view class="search-row">
<view class="search-item">
<text class="label">璇勪环鏃堕棿锛?/text>
<text class="label">评价时间:</text>
<view class="mock-date-range">
<text class="emoji">馃搮</text>
<text class="txt">寮€濮嬫棩鏈?- 缁撴潫鏃ユ湡</text>
<text class="emoji">📅</text>
<text class="txt">开始日期 - 结束日期</text>
</view>
</view>
<view class="search-item">
<text class="label">璇勪环鐘舵€侊細</text>
<view class="mock-select"><text>璇烽€夋嫨</text><text class="arrow">鈻?/text></view>
<text class="label">评价状态:</text>
<view class="mock-select"><text>请选择</text><text class="arrow">▼</text></view>
</view>
<view class="search-item">
<text class="label">瀹℃牳鐘舵€侊細</text>
<view class="mock-select"><text>璇烽€夋嫨</text><text class="arrow">鈻?/text></view>
<text class="label">审核状态:</text>
<view class="mock-select"><text>请选择</text><text class="arrow">▼</text></view>
</view>
</view>
<view class="search-row mt-16">
<view class="search-item">
<text class="label">鍟嗗搧淇℃伅锛?/text>
<input class="mock-input" placeholder="璇疯緭鍏ュ晢鍝佷俊鎭? />
<text class="label">商品信息:</text>
<input class="mock-input" placeholder="请输入商品信息" />
</view>
<view class="search-item">
<text class="label">鐢ㄦ埛鍚嶇О锛?/text>
<input class="mock-input" placeholder="璇疯緭鍏? />
<text class="label">用户名称:</text>
<input class="mock-input" placeholder="请输入" />
</view>
<button class="btn-primary">鏌ヨ</button>
<button class="btn-primary">查询</button>
</view>
</view>
<!-- 2. 鎿嶄綔琛?-->
<!-- 2. 操作行 -->
<view class="action-bar">
<button class="btn-primary">娣诲姞鑷瘎</button>
<button class="btn-white">鎵归噺瀹℃牳</button>
<button class="btn-primary">添加自评</button>
<button class="btn-white">批量审核</button>
</view>
<!-- 3. 鏁版嵁琛ㄦ牸 -->
<!-- 3. 数据表格 -->
<view class="list-card">
<view class="table-v5">
<view class="th-row">
<view class="th col-check"><text>鈻?/text></view>
<view class="th col-id"><text>璇勮ID</text></view>
<view class="th col-product"><text>鍟嗗搧淇℃伅</text></view>
<view class="th col-spec"><text>瑙勬牸</text></view>
<view class="th col-user"><text>鐢ㄦ埛鍚嶇О</text></view>
<view class="th col-score"><text>璇勫垎</text></view>
<view class="th col-content"><text>璇勪环鍐呭</text></view>
<view class="th col-reply"><text>鍥炲鍐呭</text></view>
<view class="th col-status"><text>瀹℃牳鐘舵€?/text></view>
<view class="th col-time"><text>璇勪环鏃堕棿</text></view>
<view class="th col-op"><text>鎿嶄綔</text></view>
<view class="th col-check"><text>□</text></view>
<view class="th col-id"><text>评论ID</text></view>
<view class="th col-product"><text>商品信息</text></view>
<view class="th col-spec"><text>规格</text></view>
<view class="th col-user"><text>用户名称</text></view>
<view class="th col-score"><text>评分</text></view>
<view class="th col-content"><text>评价内容</text></view>
<view class="th col-reply"><text>回复内容</text></view>
<view class="th col-status"><text>审核状态</text></view>
<view class="th col-time"><text>评价时间</text></view>
<view class="th col-op"><text>操作</text></view>
</view>
<view v-for="item in replyList" :key="item.id" class="tr-row">
<view class="td col-check"><text>鈻?/text></view>
<view class="td col-check"><text>□</text></view>
<view class="td col-id"><text>{{ item.id }}</text></view>
<view class="td col-product">
<image class="p-img" :src="item.image" mode="aspectFill" />
@@ -66,25 +66,25 @@
<view class="td col-user"><text>{{ item.username }}</text></view>
<view class="td col-score"><text>{{ item.score }}</text></view>
<view class="td col-content"><text class="blue-link">{{ item.content }}</text></view>
<view class="td col-reply"><text>{{ item.reply || '鏃? }}</text></view>
<view class="td col-reply"><text>{{ item.reply || '无' }}</text></view>
<view class="td col-status">
<text class="status-tag" :class="item.status === 1 ? 'pass' : 'wait'">
{{ item.status === 1 ? '閫氳繃' : '寰呭鏍? }}
{{ item.status === 1 ? '通过' : '待审核' }}
</text>
</view>
<view class="td col-time"><text>{{ item.time }}</text></view>
<view class="td col-op">
<text class="op-link">閫氳繃</text>
<text class="op-link">椹冲洖</text>
<text class="op-link">鍥炲</text>
<text class="op-link red">鍒犻櫎</text>
<text class="op-link">通过</text>
<text class="op-link">驳回</text>
<text class="op-link">回复</text>
<text class="op-link red">删除</text>
</view>
</view>
</view>
<!-- 鍒嗛〉 -->
<!-- 分页 -->
<view class="pagination-row">
<text class="total">鍏?{{ replyList.length }} 鏉?/text>
<text class="total">{{ replyList.length }} 条</text>
<view class="page-ctrl">
<text class="page-btn disabled">{"<"}</text>
<text class="page-num active">1</text>
@@ -102,8 +102,8 @@ const replyList = ref([
{
id: 1069,
image: 'https://img1.baidu.com/it/u=254065646,3100346083&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500',
productName: 'UR2024澶忓鏂版濂宠澶嶅彜绾姘涘洿鎰熶竴瀛楄偐鐭T鎭よUWG440060',
spec: 'XL,鍗″叾',
productName: 'UR2024夏季新款女装复古纯欲氛围感一字肩短款T恤衫UWG440060',
spec: 'XL,卡其',
username: 'demo998',
score: 3.5,
content: '22',
@@ -114,11 +114,11 @@ const replyList = ref([
{
id: 1059,
image: 'https://img1.baidu.com/it/u=254065646,3100346083&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500',
productName: 'UR2024澶忓鏂版濂宠澶嶅彜绾姘涘洿鎰熶竴瀛楄偐鐭T鎭よUWG440060',
spec: 'XL,鍗″叾',
username: '浣犲ソ鍛€',
productName: 'UR2024夏季新款女装复古纯欲氛围感一字肩短款T恤衫UWG440060',
spec: 'XL,卡其',
username: '你好呀',
score: 3.5,
content: '鐨?,
content: '的',
reply: '',
status: 0,
time: '2025-01-07 15:35:36'
@@ -126,11 +126,11 @@ const replyList = ref([
{
id: 980,
image: 'https://img1.baidu.com/it/u=254065646,3100346083&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500',
productName: 'UR2024澶忓鏂版濂宠澶嶅彜绾姘涘洿鎰熶竴瀛楄偐鐭T鎭よUWG440060',
spec: 'XL,鍗″叾',
productName: 'UR2024夏季新款女装复古纯欲氛围感一字肩短款T恤衫UWG440060',
spec: 'XL,卡其',
username: 'wx209638',
score: 5,
content: '濂?,
content: '好',
reply: '',
status: 1,
time: '2024-09-12 14:20:12'
@@ -140,9 +140,9 @@ const replyList = ref([
<style scoped lang="scss">
.product-reply-page {
/* padding removed */
padding: 20px;
background-color: #f5f7f9;
min-height: 100vh;
}
.search-card {
@@ -264,4 +264,3 @@ const replyList = ref([
}
}
</style>

View File

@@ -1,21 +1,21 @@
<template>
<template>
<view class="admin-main">
<!-- 澶撮儴鎼滅储 -->
<!-- 头部搜索 -->
<view class="search-card">
<view class="search-row">
<view class="search-item">
<text class="search-label">瑙勬牸鎼滅储:</text>
<input class="search-input" placeholder="璇疯緭鍏ヨ鏍煎悕绉? />
<text class="search-label">规格搜索:</text>
<input class="search-input" placeholder="请输入规格名称" />
</view>
<button class="btn-query">鏌ヨ</button>
<button class="btn-query">查询</button>
</view>
</view>
<!-- 鏁版嵁琛ㄦ牸鍖哄煙 -->
<!-- 数据表格区域 -->
<view class="table-card">
<view class="table-toolbar">
<button class="btn-add" @click="showModal = true">娣诲姞鍟嗗搧瑙勬牸</button>
<button class="btn-batch-del">鎵归噺鍒犻櫎</button>
<button class="btn-add" @click="showModal = true">添加商品规格</button>
<button class="btn-batch-del">批量删除</button>
</view>
<view class="table-header">
@@ -23,20 +23,20 @@
<view class="checkbox-mock"></view>
</view>
<text class="th-cell flex-1">ID</text>
<text class="th-cell flex-3">瑙勬牸鍚嶇О</text>
<text class="th-cell flex-4">鍟嗗搧瑙勬牸</text>
<text class="th-cell flex-4">鍟嗗搧灞炴€?/text>
<text class="th-cell flex-2 text-center">鎿嶄綔</text>
<text class="th-cell flex-3">规格名称</text>
<text class="th-cell flex-4">商品规格</text>
<text class="th-cell flex-4">商品属性</text>
<text class="th-cell flex-2 text-center">操作</text>
</view>
<view class="table-body">
<view v-if="list.length === 0" class="empty-box">
<text class="empty-text">鏆傛棤鏁版嵁</text>
<text class="empty-text">暂无数据</text>
</view>
<view v-for="(item, index) in list" :key="index" class="table-row">
<view class="td-cell flex-1 row-center">
<view class="checkbox-mock" :class="item.selected ? 'checked' : ''" @click="item.selected = !item.selected">
<text v-if="item.selected" class="check-mark">鉁?/text>
<text v-if="item.selected" class="check-mark">✓</text>
</view>
</view>
<text class="td-cell flex-1 color-9">{{ item.id }}</text>
@@ -44,46 +44,46 @@
<text class="td-cell flex-4">{{ item.specs }}</text>
<text class="td-cell flex-4">{{ item.attrs }}</text>
<view class="td-cell flex-2 row-center">
<text class="btn-link">缂栬緫</text>
<text class="btn-link">编辑</text>
<view class="divider"></view>
<text class="btn-link delete" @click="deleteItem(index)">鍒犻櫎</text>
<text class="btn-link delete" @click="deleteItem(index)">删除</text>
</view>
</view>
</view>
</view>
<!-- 娣诲姞瑙勬牸寮圭獥 -->
<!-- 添加规格弹窗 -->
<view class="modal-mask" v-if="showModal" @click="showModal = false">
<view class="modal-content" @click.stop>
<view class="modal-header">
<text class="modal-title">娣诲姞鍟嗗搧瑙勬牸</text>
<text class="modal-close" @click="showModal = false"></text>
<text class="modal-title">添加商品规格</text>
<text class="modal-close" @click="showModal = false">×</text>
</view>
<view class="modal-body">
<view class="modal-form">
<view class="form-item">
<view class="form-label-box"><text class="form-label">瑙勬牸鍚嶇О:</text></view>
<view class="form-label-box"><text class="form-label">规格名称:</text></view>
<view class="form-input-box">
<input class="modal-input" v-model="form.name" placeholder="璇疯緭鍏ヨ鏍煎悕绉? />
<input class="modal-input" v-model="form.name" placeholder="请输入规格名称" />
</view>
</view>
<view class="form-item">
<view class="form-label-box"><text class="form-label">鍟嗗搧瑙勬牸:</text></view>
<view class="form-label-box"><text class="form-label">商品规格:</text></view>
<view class="form-input-box">
<input class="modal-input" v-model="form.specs" placeholder="璇疯緭鍏ュ晢鍝佽鏍? />
<input class="modal-input" v-model="form.specs" placeholder="请输入商品规格" />
</view>
</view>
<view class="form-item">
<view class="form-label-box"><text class="form-label">鍟嗗搧灞炴€?</text></view>
<view class="form-label-box"><text class="form-label">商品属性:</text></view>
<view class="form-input-box">
<input class="modal-input" v-model="form.attrs" placeholder="璇疯緭鍏ュ晢鍝佸睘鎬? />
<input class="modal-input" v-model="form.attrs" placeholder="请输入商品属性" />
</view>
</view>
</view>
</view>
<view class="modal-footer">
<button class="btn-modal-cancel" @click="showModal = false">鍙栨秷</button>
<button class="btn-modal-submit" @click="saveAttr">纭畾</button>
<button class="btn-modal-cancel" @click="showModal = false">取消</button>
<button class="btn-modal-submit" @click="saveAttr">确定</button>
</view>
</view>
</view>
@@ -102,11 +102,11 @@ interface AttrItem {
}
const list = reactive<AttrItem[]>([
{ id: 104, name: '棰滆壊', specs: '绾㈣壊,钃濊壊,榛戣壊,鐧借壊', attrs: '棰滆壊灞炴€?, selected: false },
{ id: 105, name: '灏哄', specs: 'S,M,L,XL,XXL', attrs: '鏈嶈灏哄', selected: false },
{ id: 106, name: '鏉愯川', specs: '绾,娑ょ憾,鐪熶笣', attrs: '闈㈡枡鏉愯川', selected: false },
{ id: 107, name: '鍐呭瓨', specs: '8G,16G,32G', attrs: '纭欢鍙傛暟', selected: false },
{ id: 108, name: '瀛樺偍', specs: '128G,256G,512G', attrs: '瀹归噺', selected: false }
{ id: 104, name: '颜色', specs: '红色,蓝色,黑色,白色', attrs: '颜色属性', selected: false },
{ id: 105, name: '尺寸', specs: 'S,M,L,XL,XXL', attrs: '服装尺寸', selected: false },
{ id: 106, name: '材质', specs: '纯棉,涤纶,真丝', attrs: '面料材质', selected: false },
{ id: 107, name: '内存', specs: '8G,16G,32G', attrs: '硬件参数', selected: false },
{ id: 108, name: '存储', specs: '128G,256G,512G', attrs: '容量', selected: false }
])
const showModal = ref(false)
@@ -118,7 +118,7 @@ const form = reactive({
function saveAttr() {
if (!form.name) {
uni.showToast({ title: '璇疯緭鍏ヨ鏍煎悕绉?, icon: 'none' })
uni.showToast({ title: '请输入规格名称', icon: 'none' })
return
}
list.push({
@@ -132,13 +132,13 @@ function saveAttr() {
form.name = ''
form.specs = ''
form.attrs = ''
uni.showToast({ title: '娣诲姞鎴愬姛', icon: 'success' })
uni.showToast({ title: '添加成功', icon: 'success' })
}
function deleteItem(index: number) {
uni.showModal({
title: '鎻愮ず',
content: '纭畾鍒犻櫎璇ヨ鏍煎悧锛?,
title: '提示',
content: '确定删除该规格吗?',
success: (res) => {
if (res.confirm) {
list.splice(index, 1)
@@ -155,7 +155,7 @@ function deleteItem(index: number) {
min-height: 100vh;
}
/* 鎼滅储鍗$墖 */
/* 搜索卡片 */
.search-card {
background-color: #fff;
padding: 24px;
@@ -203,7 +203,7 @@ function deleteItem(index: number) {
margin-left: 0;
}
/* 琛ㄦ牸鍖哄煙 */
/* 表格区域 */
.table-card {
background-color: #fff;
padding: 24px;
@@ -348,7 +348,7 @@ function deleteItem(index: number) {
.modal-content {
width: 500px;
background-color: #fff;
border-radius: 4px;
box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}
@@ -443,4 +443,3 @@ function deleteItem(index: number) {
.flex-4 { flex: 4; }
</style>