diff --git a/config/proxy.js b/config/proxy.js index 13086ba..59751bf 100644 --- a/config/proxy.js +++ b/config/proxy.js @@ -16,8 +16,16 @@ '/saasbase/': '', }, }, + '/ordermanage/': { + target: 'http://localhost:5248', + changeOrigin: true, + secure: false, //关闭证书验证 + pathRewrite: { + '/ordermanage/': '', + }, + }, '/groupmeal/': { - target: 'http://localhost:5298', + target: 'http://10.2.1.26:21995/groupmeal/', changeOrigin: true, secure: false, //关闭证书验证 pathRewrite: { diff --git a/config/routes.js b/config/routes.js index efba58e..e20600a 100644 --- a/config/routes.js +++ b/config/routes.js @@ -156,7 +156,6 @@ export default [ }, ], }, - { name: '设备管理', icon: 'BankFilled', @@ -323,6 +322,37 @@ export default [ }, ], }, + { + name: '订单管理', + icon: 'BankFilled', + path: '/order', + routes: [ + { + name: '订单流水', + icon: 'smile', + path: '/order/orderflow', + component: './order/orderflow', + }, + { + name: '第三方订单', + icon: 'smile', + path: '/order/thirdOrder', + component: './order/thirdOrder', + }, + { + name: '店铺授权', + icon: 'smile', + path: '/order/thirdOrder', + component: './order/thirdOrder', + }, + { + name: '授权管理', + icon: 'smile', + path: '/order/thirdAuthorize', + component: './order/thirdAuthorize', + }, + ], + }, { path: '/', redirect: '/welcome', diff --git a/src/.umi-production/.cache/webpack/default-production/0.pack b/src/.umi-production/.cache/webpack/default-production/0.pack deleted file mode 100644 index 3aee32a..0000000 Binary files a/src/.umi-production/.cache/webpack/default-production/0.pack and /dev/null differ diff --git a/src/.umi-production/.cache/webpack/default-production/index.pack b/src/.umi-production/.cache/webpack/default-production/index.pack deleted file mode 100644 index 656b664..0000000 Binary files a/src/.umi-production/.cache/webpack/default-production/index.pack and /dev/null differ diff --git a/src/app.jsx b/src/app.jsx index 1fd55da..bb9e767 100644 --- a/src/app.jsx +++ b/src/app.jsx @@ -372,6 +372,31 @@ export async function getInitialState() { }, ], }, + { + name: '订单管理', + icon: 'BankFilled', + path: '/order', + routes: [ + { + name: '订单流水', + icon: 'smile', + path: '/order/orderflow', + component: './order/orderflow', + }, + { + name: '第三方订单', + icon: 'smile', + path: '/order/thirdOrder', + component: './order/thirdOrder', + }, + { + name: '授权管理', + icon: 'smile', + path: '/order/thirdAuthorize', + component: './order/thirdAuthorize', + }, + ], + }, ]; // api.queryMenus(); return data; diff --git a/src/pages/order/orderflow/index.jsx b/src/pages/order/orderflow/index.jsx new file mode 100644 index 0000000..7be80f7 --- /dev/null +++ b/src/pages/order/orderflow/index.jsx @@ -0,0 +1,304 @@ +import { DropboxOutlined, PlusOutlined, DownloadOutlined } from '@ant-design/icons'; +import { Button, message, Select, Input, Drawer, Popconfirm } from 'antd'; +import React, { useState, useRef, useEffect } from 'react'; +import { PageContainer, FooterToolbar } from '@ant-design/pro-layout'; +import ProTable from '@ant-design/pro-table'; +import ProDescriptions from '@ant-design/pro-descriptions'; +import ExportJsonExcel from 'js-export-excel'; +import api from './service'; +import OrderflowDetail from './orderflowDetail'; + +const handlerefund = async (value) => { + var data = { number: value }; + const hide = message.loading('正在发起退款'); + try { + api.StartRefund(data); + hide(); + message.success('发起退款成功,即将刷新'); + return true; + } catch (error) { + hide(); + message.error('发起退款失败,请重试'); + return false; + } +}; +const Manage = () => { + const [row, setRow] = useState(); + const [createModalVisible, handleModalVisible] = useState(false); + //获取店铺(店铺信息) + const [srdList, setsrdList] = useState([]); + const [dataList, setdataList] = useState([]); + //绑定 + const actionRef = useRef(); + const [Selectparams, setparams] = useState([]); + // 获取店铺分类、商品名称信息 + useEffect(() => { + //店铺名称(店铺信息) + function initsrdList() { + api.srdList().then((r) => { + var arr = r.data; + arr?.forEach((element) => { + element.value = element.id; + element.label = element.name; + }); + setsrdList(arr); + }); + } + + initsrdList(); + }, []); + /**导出 */ + function handleExport() { + api.GetFlowExport(Selectparams).then((res) => { + let url = URL.createObjectURL(new Blob([res])); + let filename = '订单流水.xlsx'; + let a = document.createElement('a'); + a.href = url; + a.download = filename; + a.click(); + URL.revokeObjectURL(url); + }); + } + /** 国际化配置 */ + + const columns = [ + { + title: '主键', + dataIndex: 'id', + tip: '规则名称是唯一的 key', + hideInSearch: true, + hideInTable: true, + }, + { + title: '订单时间', + dataIndex: 'order_CreateTime', + valueType: 'dateRange', + hideInTable: true, + search: { + transform: (value) => { + return { + order_CreateTime: value[0], + order_EndTime: value[1], + }; + }, + }, + }, + { + title: '手机号', + dataIndex: 'Customer_Tel', + hideInTable: true, + }, + { + title: '店铺名称', + dataIndex: 'storeId', + hideInTable: true, + valueType: 'select', + renderFormItem: () => ( + ; + } + + return defaultRender(item); + }, + }, + { + title: '操作', + dataIndex: 'option', + valueType: 'option', + render: (_, record) => [ + { + setRow(record), handleModalVisible(true); + }} + > + 查看详情 + , + // { + // api.printsmallticket({ "orderId": record.id }) + // .then(re => { + // if (re.data) { + // message.success('打印成功'); + // } else { + // message.error('打印失败'); + // } + + // }) + + // }} > + // 打印小票 + // , + ], + }, + ]; + + //下载Excel + const onDownloadExcel = async () => { + const response = await api.GetFlowExport(Selectparams) + if (response.isSuccess) { + let option = {}; //option代表的就是excel文件 + const date = new Date(); + const excelName = "订单流水" + date.toLocaleString().replaceAll('\/', '-'); + option.fileName = excelName; //excel文件名称 + const sheetHeader = ['storeTypeName','storeName','order_Number','order_OriginalMoney','order_RealMoney','refundOriginalMoney','refundRealMoney','order_Count','order_CreateTime'];; + // Object.keys(response.data[0]).forEach(item => { + // sheetHeader.push(item); + // }); + option.datas = [ + { + sheetData: response.data, //excel文件中的数据源 + sheetName: excelName, //excel文件中sheet页名称 + sheetFilter: sheetHeader, //excel文件中需显示的列数据 + sheetHeader: ['店铺分类', '店铺名称', '交易单号', '应付金额', '实付金额', + '应付金额(退)', '实付金额(退)', '子订单数量', '创建时间', + ] //excel文件中每列的表头名称 + } + ] + let toExcel = new ExportJsonExcel(option); //生成excel文件 + toExcel.saveExcel(); + } else { + message.error(response.errors || '导出失败'); + } +} + + return ( + + [ + // , + ]} + columns={columns} + //数据绑定 + request={async (params, sorter, filter) => { + if (params.storeTypeId != undefined) { + //店铺分类 + params.storeTypeId = srdTypeList[params.storeTypeId].storeTypeId; + } + const msg = await api.orderList(params); + setparams(params); + setdataList(msg.data.data); + return { + data: msg.data.data, + success: true, + total: msg.data.total, + }; + }} + > + + {!!row && ( + { + // var success = false; + + // }} + onCancel={() => { + setRow(undefined); + handleModalVisible(false); + }} + createModalVisible={createModalVisible} + values={row || {}} + /> + )} + + ); +}; + +export default Manage; diff --git a/src/pages/order/orderflow/orderflowDetail.jsx b/src/pages/order/orderflow/orderflowDetail.jsx new file mode 100644 index 0000000..ca531c0 --- /dev/null +++ b/src/pages/order/orderflow/orderflowDetail.jsx @@ -0,0 +1,228 @@ +import React, { useState, useEffect } from 'react'; +import { message, Modal, Descriptions } from 'antd'; +import ProTable from '@ant-design/pro-table'; +import ProDescriptions from '@ant-design/pro-descriptions'; +import api from './service'; +import { FrownTwoTone } from '@ant-design/icons'; + +let defaultData = {}; +const OrderflowDetail = (props) => { + const { createModalVisible, onCancel } = props; + const [orderInfo, setOrderInfo] = useState([]); + return ( + onCancel()} + maskClosable={false} + > + { + defaultData = await api.GetOrderDetails({ id: props.values.id }); + setOrderInfo(defaultData); + return Promise.resolve({ + success: true, + data: defaultData, + }); + }} + columns={[ + { + title: '会员姓名', + key: 'customer_Name', + dataIndex: 'customer_Name', + }, + { + title: '手机号', + key: 'customer_Tel', + dataIndex: 'customer_Tel', + }, + { + title: '订单流水', + key: 'order_Number', + dataIndex: 'order_Number', + }, + { + title: '订单号', + key: 'transaction_ID', + dataIndex: 'transaction_ID', + }, + { + title: '交易单号', + key: 'trade_no', + dataIndex: 'trade_no', + }, + { + title: '排队号', + key: 'order_SortID', + dataIndex: 'order_SortID', + }, + { + title: '折扣', + key: 'discount', + dataIndex: 'discount', + }, + { + title: '实付金额', + dataIndex: 'order_RealMoney', + valueType: 'money', + fieldProps: { + moneySymbol: '¥', + }, + }, + { + title: '应付金额', + dataIndex: 'order_OriginalMoney', + valueType: 'money', + fieldProps: { + moneySymbol: '¥', + }, + }, + { + title: '实付金额(退)', + dataIndex: 'refundRealMoney', + valueType: 'money', + fieldProps: { + moneySymbol: '¥', + }, + }, + { + title: '应付金额(退)', + dataIndex: 'refundOriginalMoney', + valueType: 'money', + fieldProps: { + moneySymbol: '¥', + }, + }, + + { + title: '数量', + dataIndex: 'order_Count', + hideInSearch: true, + }, + { + title: '支付方式', + dataIndex: 'payMode', + key: 'payMode', + }, + + { + title: '订单状态', + dataIndex: 'order_Status', + key: 'order_Status', + }, + { + title: '消费金额', + dataIndex: 'recharge', + key: 'recharge', + }, + { + title: '消费赠送金额', + dataIndex: 'rechargeBalance', + key: 'rechargeBalance', + }, + ]} + > +

商品列表

+ { + defaultData = await api.GetOrderDetails({ id: props.values.id }); + return { + data: defaultData.detailList, + success: true, + }; + }} + columns={[ + { + title: '商品分类', + key: 'goodsTypeName', + dataIndex: 'goodsTypeName', + }, + { + title: '商品名称', + key: 'goodsName', + dataIndex: 'goodsName', + }, + { + title: '应付金额', + key: 'originalMoney', + dataIndex: 'originalMoney', + valueType: 'money', + fieldProps: { + moneySymbol: '¥', + }, + }, + { + title: '实付金额', + dataIndex: 'realMoney', + valueType: 'money', + fieldProps: { + moneySymbol: '¥', + }, + }, + { + title: '操作', + dataIndex: 'option', + valueType: 'option', + render: (_, record) => [ + { + api.printsmallticket({ "orderId": props.values.id, "subOrderId": record.id }) + .then(re => { + debugger + if (re.data) { + message.success('打印成功'); + } else { + message.error('打印失败'); + } + + }) + + }} > + 打印小票 + , + ], + }, + + ]} + toolBarRender={false} + search={false} + /> + + {defaultData?.paperCoupons?.map(item => { + return ( + <> + {item.platformName } + {item.name} + {item.amount} + + ); + })} + + + + {defaultData?.goodsCoupons?.map(item => { + return ( + <> + {item.platformName } + {item.name} + {item.goodsName} + {item.goodsAmount} + {item.platformAmount} + + ); + })} + + +
+ ); +}; + +export default OrderflowDetail; diff --git a/src/pages/order/orderflow/service.js b/src/pages/order/orderflow/service.js new file mode 100644 index 0000000..9c4e989 --- /dev/null +++ b/src/pages/order/orderflow/service.js @@ -0,0 +1,116 @@ +// @ts-ignore + +/* eslint-disable */ +import { request } from 'umi'; + +export default { + /** 获取订单流水信息*/ + orderList(data) { + data.isreport = true; + return request(`/ordermanage/api/Order/PostDetail`, { + method: 'Post', + data: data, + // params: { ...params }, + // ...(options || {}), + }); + }, + + /** + * 查询店铺信息(设备信息) + */ + srdList(data) { + return request('/groupmeal/api/shop/alllist', { + method: 'GET' + }); +}, + +GetFlowExport(data) { + return request(`/ordermanage/api/Order/GetFlowExport`, { + method: 'Post', + data: data + + // params: { ...params }, + // ...(options || {}), + }); +}, + + + + + + + + + + + + + + + + + /** + * 查询店铺分类(设备类型)信息 + */ + srdTypeList(data) { + return request(`/kitchen/api/storetype/list`, { + method: 'Post', + data: data, + // params: { ...params }, + // ...(options || {}), + }); + }, + + + /** + * 查询商品信息 + */ + goodsList(data) { + return request(`/kitchen/api/goodes/list`, { + method: 'Post', + data: data, + // params: { ...params }, + // ...(options || {}), + }); + }, + /** + * 查询商品类型 + */ + goodsTypeList(data) { + return request(`/kitchen/api/goodstype/list`, { + method: 'Post', + data: data, + // params: { ...params }, + // ...(options || {}), + }); + }, + StartRefund(data) { + return request(`/kitchen/api/refund/StartOrderRefund`, { + method: 'Post', + params: data, + // params: { ...params }, + // ...(options || {}), + }); + }, + GetOrderDetails(data) { + return request(`/kitchen/api/Order/GetOrderDetails`, { + method: 'Post', + params: data, + // params: { ...params }, + // ...(options || {}), + }); + }, + + + // 打印小票 + printsmallticket(data) { + return request(`/kitchen/api/printer/print-small-ticket`, { + method: 'Post', + data: data, + // params: { ...params }, + // ...(options || {}), + }); + }, +}; + + diff --git a/src/pages/order/thirdAuthorize/index.jsx b/src/pages/order/thirdAuthorize/index.jsx new file mode 100644 index 0000000..2cb8728 --- /dev/null +++ b/src/pages/order/thirdAuthorize/index.jsx @@ -0,0 +1,209 @@ +import { DropboxOutlined, PlusOutlined, DownloadOutlined } from '@ant-design/icons'; +import { Button, message, Modal, Input, Form, Select, Popconfirm } from 'antd'; +import React, { useState, useRef, useEffect } from 'react'; +import { PageContainer, FooterToolbar } from '@ant-design/pro-layout'; +import ProTable from '@ant-design/pro-table'; +import ProDescriptions from '@ant-design/pro-descriptions'; +import api from './service'; + +const Manage = () => { + const [row, setRow] = useState(); + //获取店铺(店铺信息) + const [shopList, setShopList] = useState([]); + //绑定 + const actionRef = useRef(); + + const [isModalOpen, setIsModalOpen] = useState(false); + const [form] = Form.useForm(); + + + // 获取店铺分类、商品名称信息 + useEffect(() => { + getShopList(); + }, []); + const getShopList = async () => { + const response = await api.GetAllStore(); + if (response.statusCode == 200) { + setShopList(response.data); + } else { + message.error(response.msg || '获取店铺列表失败'); + } + + } + + const columns = [ + { + title: '主键', + dataIndex: 'id', + tip: '规则名称是唯一的 key', + hideInSearch: true, + hideInTable: true, + }, + { + title: '归属场景', + dataIndex: 'storeId', + ellipsis: true, + render: (_, record) => { + const find = shopList.find(item => item.id === record.storeId); + if (find) { + return
{find.name}
+ } + } + }, + { + title: '授权码', + dataIndex: 'authorizeCode', + hideInSearch: true, + }, + { + title: '操作', + dataIndex: 'option', + valueType: 'option', + width: 200, + render: (_, record) => [ + { + api.Update({ id: record.id }).then((re) => { + if (re.data) { + message.success('修改成功'); + setIsModalOpen(false); + actionRef.current.reload(); + } else { + message.error('修改失败'); + } + }); + }} + okText="确定" + cancelText="取消" > + { + + }} > + 重新授权 + + , + { + api.Del(record.id).then((re) => { + if (re.data) { + message.success('删除成功'); + setIsModalOpen(false); + actionRef.current.reload(); + } else { + message.error('删除成功'); + } + }); + }} + okText="确定" + cancelText="取消" > + { + + }} > + 删除 + + + + ], + }, + ]; + + + + return ( + + [ + , + ]} + columns={columns} + //数据绑定 + request={async (params, sorter, filter) => { + const msg = await api.page(params); + return { + data: msg.data.data, + success: true, + total: msg.data.total, + }; + }} + > + + <> + { form.submit() }} onCancel={() => { + setIsModalOpen(false); + }}> +
{ + if (value.id) { + api.Update(value).then((re) => { + if (re.data) { + message.success('修改成功'); + handleModalVisible(false); + actionRef.current.reload(); + } else { + message.error('修改失败'); + } + }); + } else { + api.Create(value).then((re) => { + if (re.data) { + setIsModalOpen(false); + message.success('添加成功'); + actionRef.current.reload(); + } else { + message.error(re.errors || '添加失败'); + } + }); + + } + }} + > + + + + +
+
+ + +
+ ); +}; + +export default Manage; diff --git a/src/pages/order/thirdAuthorize/service.js b/src/pages/order/thirdAuthorize/service.js new file mode 100644 index 0000000..9b26fb4 --- /dev/null +++ b/src/pages/order/thirdAuthorize/service.js @@ -0,0 +1,42 @@ +// @ts-ignore + +/* eslint-disable */ +import { request } from 'umi'; + +export default { + + page(data) { + data.isreport = true; + return request(`/ordermanage/api/ThirdAuthorize/Page`, { + method: 'Post', + data: data, + }); + }, + GetAllStore() { + return request('/groupmeal/api/shop/alllist', { + method: 'GET' + }); + }, + Create(data) { + return request('/ordermanage/api/ThirdAuthorize/Create', { + method: 'Post', + data: data, + }); + }, + Update(data) { + return request('/ordermanage/api/ThirdAuthorize/Update', { + method: 'Post', + data: data, + }); + }, + Del(data) { + return request('/ordermanage/api/ThirdAuthorize/Del?id='+data, { + method: 'Post', + }); + }, + + + +}; + + diff --git a/src/pages/order/thirdOrder/index.jsx b/src/pages/order/thirdOrder/index.jsx new file mode 100644 index 0000000..90582ad --- /dev/null +++ b/src/pages/order/thirdOrder/index.jsx @@ -0,0 +1,124 @@ +import { DropboxOutlined, PlusOutlined, DownloadOutlined } from '@ant-design/icons'; +import { message, Modal, Input, Form, Space, Table, Tag } from 'antd'; +import React, { useState, useRef, useEffect } from 'react'; +import { PageContainer, FooterToolbar } from '@ant-design/pro-layout'; +import ProTable from '@ant-design/pro-table'; +import ProDescriptions from '@ant-design/pro-descriptions'; +import api from './service'; +const handlerefund = async (value) => { + var data = { number: value }; + const hide = message.loading('正在发起退款'); + try { + api.StartRefund(data); + hide(); + message.success('发起退款成功,即将刷新'); + return true; + } catch (error) { + hide(); + message.error('发起退款失败,请重试'); + return false; + } +}; +const Manage = () => { + const [row, setRow] = useState(); + //绑定 + const actionRef = useRef(); + const [form] = Form.useForm(); + const [isModalOpen, setIsModalOpen] = useState(false); + + const [thirdOrderInfo, setThirdOrderInfo] = useState(false); + + + // 获取店铺分类、商品名称信息 + useEffect(() => { + + }, []); + + const columns = [ + { + title: '主键', + dataIndex: 'id', + tip: '规则名称是唯一的 key', + hideInSearch: true, + hideInTable: true, + }, + { + title: '订单编号', + dataIndex: 'orderNum', + }, + { + title: '同步时间', + dataIndex: 'createAt', + hideInSearch: true, + }, + { + title: '操作', + dataIndex: 'option', + valueType: 'option', + width: 200, + render: (_, record) => [ + { + var data = await api.getThirdOrderInfo(record.id); + setThirdOrderInfo(data.data.thirdOrderInfos); + setIsModalOpen(true); + }} > + 查看详情 + + ], + }, + ]; + + const columnInfos = [ + { + title: '商品名称', + dataIndex: 'goodsName', + key: 'goodsName', + render: (text) => {text}, + }, + { + title: '数量', + dataIndex: 'count', + key: 'count', + } + ]; + return ( + + [ + // , + // ]} + columns={columns} + //数据绑定 + request={async (params, sorter, filter) => { + const msg = await api.page(params); + return { + data: msg.data.data, + success: true, + total: msg.data.total, + }; + }} + > + + <> + { }} onCancel={() => { setIsModalOpen(false); }}> + + + + + ); +}; + +export default Manage; diff --git a/src/pages/order/thirdOrder/service.js b/src/pages/order/thirdOrder/service.js new file mode 100644 index 0000000..8f66f56 --- /dev/null +++ b/src/pages/order/thirdOrder/service.js @@ -0,0 +1,135 @@ +// @ts-ignore + +/* eslint-disable */ +import { request } from 'umi'; + +export default { + + page(data) { + data.isreport = true; + return request(`/ordermanage/api/Order/ThirdOrderPage`, { + method: 'Post', + data: data, + }); + }, + + getThirdOrderInfo(data) { + return request(`/ordermanage/api/Order/GetThirdOrderInfo?thirdOrderId=`+data, { + method: 'get', + }); + }, + + + + + + /** 获取订单流水信息*/ + orderList(data) { + data.isreport = true; + return request(`/ordermanage/api/Order/PostDetail`, { + method: 'Post', + data: data, + // params: { ...params }, + // ...(options || {}), + }); + }, + + /** + * 查询店铺信息(设备信息) + */ + srdList(data) { + return request('/groupmeal/api/shop/alllist', { + method: 'GET' + }); +}, + +GetFlowExport(data) { + return request(`/ordermanage/api/Order/GetFlowExport`, { + method: 'Post', + data: data + + // params: { ...params }, + // ...(options || {}), + }); +}, + + + + + + + + + + + + + + + + + /** + * 查询店铺分类(设备类型)信息 + */ + srdTypeList(data) { + return request(`/kitchen/api/storetype/list`, { + method: 'Post', + data: data, + // params: { ...params }, + // ...(options || {}), + }); + }, + + + /** + * 查询商品信息 + */ + goodsList(data) { + return request(`/kitchen/api/goodes/list`, { + method: 'Post', + data: data, + // params: { ...params }, + // ...(options || {}), + }); + }, + /** + * 查询商品类型 + */ + goodsTypeList(data) { + return request(`/kitchen/api/goodstype/list`, { + method: 'Post', + data: data, + // params: { ...params }, + // ...(options || {}), + }); + }, + StartRefund(data) { + return request(`/kitchen/api/refund/StartOrderRefund`, { + method: 'Post', + params: data, + // params: { ...params }, + // ...(options || {}), + }); + }, + GetOrderDetails(data) { + return request(`/kitchen/api/Order/GetOrderDetails`, { + method: 'Post', + params: data, + // params: { ...params }, + // ...(options || {}), + }); + }, + + + // 打印小票 + printsmallticket(data) { + return request(`/kitchen/api/printer/print-small-ticket`, { + method: 'Post', + data: data, + // params: { ...params }, + // ...(options || {}), + }); + }, +}; + +