|
|
@@ -1,7 +1,13 @@ |
|
|
|
import React, { useState } from 'react'; |
|
|
|
import { Button, Card, Image, Timeline } from 'antd'; |
|
|
|
import React, { useState, useEffect } from 'react'; |
|
|
|
import { Button, Card, Image, Timeline, message } from 'antd'; |
|
|
|
import styles from './index.less'; |
|
|
|
import { ExclamationCircleOutlined } from '@ant-design/icons'; |
|
|
|
import { history } from 'umi'; |
|
|
|
import orderReportAPI from "./service"; |
|
|
|
import { PageContainer } from '@ant-design/pro-layout'; |
|
|
|
|
|
|
|
const orderNumber = history.location.query.orderNumber; |
|
|
|
|
|
|
|
/** |
|
|
|
* 订单详情 |
|
|
|
* @returns |
|
|
@@ -9,46 +15,15 @@ import { ExclamationCircleOutlined } from '@ant-design/icons'; |
|
|
|
export default function Index() { |
|
|
|
|
|
|
|
const [orderInfo, setOrderInfo] = useState({ |
|
|
|
id: '1008611', |
|
|
|
sortId: '99', //取餐号 |
|
|
|
orderDetail: [ //订单商品列表 |
|
|
|
{ |
|
|
|
id: 'cda34f2c-7965-46ef-8517-0bc6fae87a71', |
|
|
|
goodName: '牛肉面', |
|
|
|
goodImg: 'https://hbl-1305371387.cos.ap-chengdu.myqcloud.com/Franchisee//goods/132969698918875531.jpg', |
|
|
|
order_Status: 3, |
|
|
|
originalMoney: 0.03 |
|
|
|
}, |
|
|
|
{ |
|
|
|
id: 'cda34f2c-7965-46ef-8517-0bc6fae87a72', |
|
|
|
goodName: '姜鸭面', |
|
|
|
goodImg: 'https://hbl-1305371387.cos.ap-chengdu.myqcloud.com/Franchisee//goods/132969698918875531.jpg', |
|
|
|
order_Status: 3, |
|
|
|
originalMoney: 0.03 |
|
|
|
}, |
|
|
|
], |
|
|
|
discountMoney: 0.02, //优惠金额 |
|
|
|
orderRealMoney: 0.01, //支付金额 |
|
|
|
orderNumber: '202205201022415338172', |
|
|
|
createdAt: '2022-05-20 02:22:41', |
|
|
|
orderSourceFrom: 0, //桌号 |
|
|
|
payMode: 0 //支付方式 |
|
|
|
}); |
|
|
|
|
|
|
|
const [memberInfo, setMemberInfo] = useState({ |
|
|
|
id: '4fb28567-8294-4dfc-b2ca-485dc1310837', |
|
|
|
nickName: 'Emperor_', |
|
|
|
phone: '18200000000', |
|
|
|
headImgUrl: 'https://thirdwx.qlogo.cn/mmopen/vi_32/Tnw5gbRSiaekqqHYERFT4x8o8GSkkBINuStbvml530FYjyeO2EKSYouKCAZLHBX3PDLLYInn130vwda6Y3gK0yA/132', |
|
|
|
createAt: '2022-05-18 11:20:44', |
|
|
|
address: '四川省 成都市 高新区 环球中心9-11B' |
|
|
|
memberInfo: {}, |
|
|
|
goodsInfo: [] |
|
|
|
}); |
|
|
|
|
|
|
|
const [saleAfterInfo, setSaleAfterInfo] = useState([ |
|
|
|
{ |
|
|
|
id: "acc670f8-317f-4c2d-94f5-f7af12c80ebd", |
|
|
|
createdAt: "2022-05-18 07:52:09", |
|
|
|
stutasStr: "待处理" |
|
|
|
stutasStr: "申请退款" |
|
|
|
}, |
|
|
|
{ |
|
|
|
id: "acc670f8-317f-4c2d-94f5-f7af12c80eb1", |
|
|
@@ -57,157 +32,169 @@ export default function Index() { |
|
|
|
}, |
|
|
|
]); |
|
|
|
|
|
|
|
const onQueryOrderDetail = async () => { |
|
|
|
if (orderNumber) { |
|
|
|
const response = await orderReportAPI.getOrderReporByNumber(orderNumber); |
|
|
|
if (response.statusCode === 200) { |
|
|
|
setOrderInfo(response.data); |
|
|
|
} else { |
|
|
|
message.error(response.errors || '订单详情获取失败'); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
useEffect(() => { |
|
|
|
onQueryOrderDetail(); |
|
|
|
}, []); |
|
|
|
|
|
|
|
return ( |
|
|
|
<div className={styles['order-detail-container']}> |
|
|
|
{/* 用户基本信息 */} |
|
|
|
<div className={styles['order-head-card']}> |
|
|
|
<div className={styles['order-head']}> |
|
|
|
<div className={styles['order-number']}> |
|
|
|
#{orderInfo.sortId} |
|
|
|
</div> |
|
|
|
<div className={styles['order-cook-state']}> |
|
|
|
立即制作 |
|
|
|
</div> |
|
|
|
<div className={styles['order-cook-date']}> |
|
|
|
2022-6-23 10:36:42 前制作完成 |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
<div className={styles['member-info']}> |
|
|
|
<div className={styles['member-info-img']}> |
|
|
|
<img src={memberInfo.headImgUrl} alt="用户头像"></img> |
|
|
|
<PageContainer> |
|
|
|
<div className={styles['order-detail-container']}> |
|
|
|
{/* 用户基本信息 */} |
|
|
|
<div className={styles['order-head-card']}> |
|
|
|
<div className={styles['order-head']}> |
|
|
|
<div className={styles['order-number']}> |
|
|
|
#0 |
|
|
|
</div> |
|
|
|
<div className={styles['order-cook-state']}> |
|
|
|
订单时间 |
|
|
|
</div> |
|
|
|
<div className={styles['order-cook-date']}> |
|
|
|
{orderInfo.createdAt} |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
<div className={styles['member-info-row']}> |
|
|
|
<div className={styles['member-info-head']}> |
|
|
|
{memberInfo.nickName} |
|
|
|
<div className={styles['member-info']}> |
|
|
|
<div className={styles['member-info-img']}> |
|
|
|
<Image |
|
|
|
width={100} |
|
|
|
height={100} |
|
|
|
src={orderInfo.memberInfo.headUrl} |
|
|
|
fallback="" |
|
|
|
/> |
|
|
|
</div> |
|
|
|
<div className={styles['member-info-label']}> |
|
|
|
<span>#门店新客</span> |
|
|
|
<span>#门店会员</span> |
|
|
|
<div className={styles['member-info-row']}> |
|
|
|
<div className={styles['member-info-head']}> |
|
|
|
{orderInfo.memberInfo.memberName || '系统用户'} |
|
|
|
</div> |
|
|
|
<div className={styles['member-info-label']}> |
|
|
|
<span>#门店新客</span> |
|
|
|
<span>#门店会员</span> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
<div className={styles['member-info-privacy']}> |
|
|
|
<ExclamationCircleOutlined /> |
|
|
|
<span>为保证服务体验,您在拨打或接听隐私号电话时,可能被录音</span> |
|
|
|
</div> |
|
|
|
<div className={styles['member-info-item']}> |
|
|
|
<span className={styles['member-info-prefix']}> |
|
|
|
顾客电话 |
|
|
|
</span> |
|
|
|
<span className={styles['member-info-suffix']}> |
|
|
|
{memberInfo.phone} |
|
|
|
</span> |
|
|
|
</div> |
|
|
|
<div className={styles['member-info-item']}> |
|
|
|
<span className={styles['member-info-prefix']}> |
|
|
|
顾客地址 |
|
|
|
</span> |
|
|
|
<span className={styles['member-info-suffix']}> |
|
|
|
{memberInfo.address} |
|
|
|
</span> |
|
|
|
</div> |
|
|
|
<div className={styles['prepare-meals']}> |
|
|
|
<div className={styles['member-info-privacy']}> |
|
|
|
<ExclamationCircleOutlined /> |
|
|
|
<span>为保证服务体验,您在拨打或接听隐私号电话时,可能被录音</span> |
|
|
|
</div> |
|
|
|
<div className={styles['member-info-item']}> |
|
|
|
<span className={styles['member-info-prefix']}> |
|
|
|
顾客电话 |
|
|
|
</span> |
|
|
|
<span className={styles['member-info-suffix']}> |
|
|
|
{orderInfo.memberInfo.phone || '暂无电话'} |
|
|
|
</span> |
|
|
|
</div> |
|
|
|
{/* <div className={styles['prepare-meals']}> |
|
|
|
<div className={styles['prepare-meals-title']}> |
|
|
|
备餐状态 |
|
|
|
</div> |
|
|
|
<div className={styles['prepare-meals-status']}> |
|
|
|
制作中 |
|
|
|
</div> |
|
|
|
</div> */} |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
{/* 订单数据 */} |
|
|
|
<div className={styles['order-base-card']}> |
|
|
|
<div className={styles['goods-title']}> |
|
|
|
订单信息 |
|
|
|
</div> |
|
|
|
<div className={styles['goods-calc-item']}> |
|
|
|
<div className={styles['goods-calc-prefix']}>订单编号</div> |
|
|
|
<div className={styles['goods-calc-sufix']}>{orderInfo.orderNumber}</div> |
|
|
|
</div> |
|
|
|
<div className={styles['goods-calc-item']}> |
|
|
|
<div className={styles['goods-calc-prefix']}>支付方式</div> |
|
|
|
<div className={styles['goods-calc-sufix']}>{orderInfo.payMode === 0 ? '微信支付' : '其他支付'}</div> |
|
|
|
</div> |
|
|
|
<div className={styles['goods-calc-item']}> |
|
|
|
<div className={styles['goods-calc-prefix']}>下单时间</div> |
|
|
|
<div className={styles['goods-calc-sufix']}>{orderInfo.createdAt}</div> |
|
|
|
</div> |
|
|
|
<div className={styles['goods-calc-item']}> |
|
|
|
<div className={styles['goods-calc-prefix']}>就餐人数</div> |
|
|
|
<div className={styles['goods-calc-sufix']}>商家按餐量提供</div> |
|
|
|
</div> |
|
|
|
<div className={styles['goods-calc-item']}> |
|
|
|
<div className={styles['goods-calc-prefix']}>桌台号码</div> |
|
|
|
<div className={styles['goods-calc-sufix']}>{orderInfo.orderSourceFrom}</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
{/* 商品信息 */} |
|
|
|
<div className={styles['goods-card']}> |
|
|
|
<div className={styles['goods-title']}> |
|
|
|
商品信息 |
|
|
|
{/* 订单数据 */} |
|
|
|
<div className={styles['order-base-card']}> |
|
|
|
<div className={styles['goods-title']}> |
|
|
|
订单信息 |
|
|
|
</div> |
|
|
|
<div className={styles['goods-calc-item']}> |
|
|
|
<div className={styles['goods-calc-prefix']}>订单编号</div> |
|
|
|
<div className={styles['goods-calc-sufix']}>{orderInfo.orderNumber}</div> |
|
|
|
</div> |
|
|
|
<div className={styles['goods-calc-item']}> |
|
|
|
<div className={styles['goods-calc-prefix']}>支付方式</div> |
|
|
|
<div className={styles['goods-calc-sufix']}>微信支付</div> |
|
|
|
</div> |
|
|
|
<div className={styles['goods-calc-item']}> |
|
|
|
<div className={styles['goods-calc-prefix']}>下单时间</div> |
|
|
|
<div className={styles['goods-calc-sufix']}>{orderInfo.createdAt}</div> |
|
|
|
</div> |
|
|
|
<div className={styles['goods-calc-item']}> |
|
|
|
<div className={styles['goods-calc-prefix']}>就餐人数</div> |
|
|
|
<div className={styles['goods-calc-sufix']}>商家按餐量提供</div> |
|
|
|
</div> |
|
|
|
<div className={styles['goods-calc-item']}> |
|
|
|
<div className={styles['goods-calc-prefix']}>桌台号码</div> |
|
|
|
<div className={styles['goods-calc-sufix']}>0</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
<div className={styles['goods-list']}> |
|
|
|
{ |
|
|
|
orderInfo.orderDetail.map(item => { |
|
|
|
return ( |
|
|
|
<div className={styles['goods-item']} key={item.id}> |
|
|
|
<div className={styles['goods-item-img']}> |
|
|
|
<img src={item.goodImg} alt="商品图片"></img> |
|
|
|
</div> |
|
|
|
<div className={styles['goods-item-name']}> |
|
|
|
{item.goodName} |
|
|
|
</div> |
|
|
|
<div className={styles['goods-item-price']}> |
|
|
|
¥{item.originalMoney} |
|
|
|
</div> |
|
|
|
<div className={styles['goods-item-count']}> |
|
|
|
x1份 |
|
|
|
</div> |
|
|
|
<div className={`${styles['goods-item-state']} ${styles['product-show-state']} ${styles[`product-show-${item.order_Status}`]}`}> |
|
|
|
{item.order_Status === 0 ? '等待制作' : ''} |
|
|
|
{item.order_Status === 1 ? '制作中' : ''} |
|
|
|
{item.order_Status === 2 ? '等待取餐' : ''} |
|
|
|
{item.order_Status === 3 ? '取餐完成' : ''} |
|
|
|
{item.order_Status === 99998 ? '正常订单' : ''} |
|
|
|
{item.order_Status === 99999 ? '异常订单' : ''} |
|
|
|
{/* 商品信息 */} |
|
|
|
<div className={styles['goods-card']}> |
|
|
|
<div className={styles['goods-title']}> |
|
|
|
商品信息 |
|
|
|
</div> |
|
|
|
<div className={styles['goods-list']}> |
|
|
|
{ |
|
|
|
orderInfo.goodsInfo.map(item => { |
|
|
|
return ( |
|
|
|
<div className={styles['goods-item']} key={item.goodsId}> |
|
|
|
<div className={styles['goods-item-img']}> |
|
|
|
<Image |
|
|
|
width={80} |
|
|
|
height={80} |
|
|
|
src={item.goodsImg} |
|
|
|
fallback="" |
|
|
|
/> |
|
|
|
</div> |
|
|
|
<div className={styles['goods-item-name']}> |
|
|
|
{item.goodsName || '暂无名称'} |
|
|
|
</div> |
|
|
|
<div className={styles['goods-item-price']}> |
|
|
|
¥{item.memberPrice} |
|
|
|
</div> |
|
|
|
<div className={styles['goods-item-count']}> |
|
|
|
x{item.count}份 |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
) |
|
|
|
}) |
|
|
|
} |
|
|
|
</div> |
|
|
|
{/* 小计 */} |
|
|
|
<div className={styles['goods-calc']}> |
|
|
|
<div className={styles['goods-calc-title']}>小计</div> |
|
|
|
<div className={styles['goods-calc-item']}> |
|
|
|
<div className={styles['goods-calc-prefix']}>优惠金额</div> |
|
|
|
<div className={styles['goods-calc-sufix']}>¥{orderInfo.discountMoney}</div> |
|
|
|
) |
|
|
|
}) |
|
|
|
} |
|
|
|
</div> |
|
|
|
<div className={`${styles['goods-calc-item']} ${styles['goods-calc-pay']}`}> |
|
|
|
<div className={styles['goods-calc-prefix']}>支付金额</div> |
|
|
|
<div className={styles['goods-calc-sufix']}>¥{orderInfo.orderRealMoney}</div> |
|
|
|
{/* 小计 */} |
|
|
|
<div className={styles['goods-calc']}> |
|
|
|
<div className={styles['goods-calc-title']}>小计</div> |
|
|
|
<div className={styles['goods-calc-item']}> |
|
|
|
<div className={styles['goods-calc-prefix']}>优惠金额</div> |
|
|
|
<div className={styles['goods-calc-sufix']}>¥{orderInfo.discountMoney}</div> |
|
|
|
</div> |
|
|
|
<div className={`${styles['goods-calc-item']} ${styles['goods-calc-pay']}`}> |
|
|
|
<div className={styles['goods-calc-prefix']}>支付金额</div> |
|
|
|
<div className={styles['goods-calc-sufix']}>¥{orderInfo.orderRealMoney}</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
{/* 售后信息 */} |
|
|
|
<div className={styles['sale-after-card']}> |
|
|
|
<div className={styles['goods-title']}> |
|
|
|
售后信息 |
|
|
|
{/* 售后信息 */} |
|
|
|
<div className={styles['sale-after-card']}> |
|
|
|
<div className={styles['goods-title']}> |
|
|
|
售后信息 |
|
|
|
</div> |
|
|
|
<Timeline> |
|
|
|
{ |
|
|
|
saleAfterInfo.map(item => { |
|
|
|
return ( |
|
|
|
<Timeline.Item color="green" key={item.id}> |
|
|
|
<div className={styles['sale-after-line']}> |
|
|
|
{item.createdAt} {item.stutasStr} |
|
|
|
</div> |
|
|
|
</Timeline.Item> |
|
|
|
) |
|
|
|
}) |
|
|
|
} |
|
|
|
</Timeline> |
|
|
|
</div> |
|
|
|
<Timeline> |
|
|
|
{ |
|
|
|
saleAfterInfo.map(item => { |
|
|
|
return ( |
|
|
|
<Timeline.Item color="green" key={item.id}> |
|
|
|
<div className={styles['sale-after-line']}> |
|
|
|
{item.createdAt} {item.stutasStr} |
|
|
|
</div> |
|
|
|
</Timeline.Item> |
|
|
|
) |
|
|
|
}) |
|
|
|
} |
|
|
|
</Timeline> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</PageContainer> |
|
|
|
|
|
|
|
) |
|
|
|
} |