dining.js 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. import { api } from '@/utils/request.js';
  2. import { BASE_API_URL } from '@/settings/siteSetting.js';
  3. import { useUserStore } from '@/store/user.js';
  4. // 微信登录
  5. export const DiningUserWechatLogin = (params) => api.post({ url: '/dining/user/wechatLogin', params });
  6. // 获取用户信息(GET /dining/user/getUserInfo),登录后调用以拿到头像等
  7. export const GetUserInfo = () => api.get({ url: '/dining/user/getUserInfo' });
  8. // 更新用户个人信息(POST /dining/user/updateProfile,body 为 dto)
  9. export const PostUpdateProfile = (dto) =>
  10. api.post({ url: '/dining/user/updateProfile', params: dto });
  11. // 文件上传(POST /file/upload,multipart,返回图片 URL/path 供 avatarUrl 使用)
  12. function uploadFileToServerImpl(filePath) {
  13. const userStore = useUserStore();
  14. return new Promise((resolve, reject) => {
  15. uni.uploadFile({
  16. url: BASE_API_URL+'/dining/file/upload',
  17. filePath,
  18. name: 'file',
  19. header: { Authorization: userStore.getToken || '' },
  20. success: (res) => {
  21. if (res.statusCode === 200) {
  22. try {
  23. const data = typeof res.data === 'string' ? JSON.parse(res.data) : res.data;
  24. const payload = data?.data ?? data;
  25. const url = payload?.url ?? payload?.path ?? payload?.relativePath ?? (typeof payload === 'string' ? payload : '');
  26. resolve(url || '');
  27. } catch (e) {
  28. reject(e);
  29. }
  30. } else {
  31. reject(new Error(res.data || '上传失败'));
  32. }
  33. },
  34. fail: reject
  35. });
  36. });
  37. }
  38. export const uploadFileToServer = uploadFileToServerImpl;
  39. export const uploadFileToSever = uploadFileToServerImpl; // 兼容拼写错误
  40. // 点餐页数据(入参 dinerCount 就餐人数、tableId 桌号)
  41. export const DiningOrderFood = (params) => api.get({ url: '/store/dining/page-info', params });
  42. // 门店详情(GET /store/info/detail/{storeId},入参 storeId)
  43. export const GetStoreDetail = (storeId) =>
  44. api.get({ url: `/store/info/detail/${encodeURIComponent(storeId)}` });
  45. // 菜品种类(入参 storeId,GET /store/info/categories?storeId=)
  46. export const GetStoreCategories = (params) => api.get({ url: '/store/info/categories', params });
  47. // 根据菜品种类获取菜品(入参 categoryId,GET /store/info/cuisines?categoryId=)
  48. export const GetStoreCuisines = (params) => api.get({ url: '/store/info/cuisines', params });
  49. // 菜品详情(GET /store/dining/cuisine/{cuisineId},入参 cuisineId 菜品ID、tableId 桌号ID 传 query)
  50. export const GetCuisineDetail = (cuisineId, tableId) => {
  51. const id = cuisineId != null ? encodeURIComponent(cuisineId) : '';
  52. const url = id ? `/store/dining/cuisine/${id}` : '/store/dining/cuisine/0';
  53. const params = tableId != null && tableId !== '' ? { tableId } : {};
  54. return api.get({ url, params });
  55. };
  56. // 获取购物车(GET /store/order/cart/{tableId},建立 SSE 连接之后调用)
  57. export const GetOrderCart = (tableId) =>
  58. api.get({ url: `/store/order/cart/${encodeURIComponent(tableId)}` });
  59. // 加入购物车(POST /store/order/cart/add,dto: { cuisineId 菜品ID, quantity 数量, tableId 桌号ID })
  60. export const PostOrderCartAdd = (dto) =>
  61. api.post({ url: '/store/order/cart/add', params: dto });
  62. // 更新购物车(PUT /store/order/cart/update,请求类型 x-www-form-urlencoded,由 request 层 formUrlEncoded 封装)
  63. export const PostOrderCartUpdate = (params) =>
  64. api.put({ url: '/store/order/cart/update', params, formUrlEncoded: true });
  65. // 清空购物车(DELETE /store/order/cart/clear,入参 tableId:query + body 双传,兼容不同后端)
  66. export const PostOrderCartClear = (tableId) => {
  67. const id = tableId != null ? String(tableId) : '';
  68. const url = id ? `/store/order/cart/clear?tableId=${encodeURIComponent(id)}` : '/store/order/cart/clear';
  69. return api.delete({ url, params: id ? { tableId: id } : {} });
  70. };
  71. // 创建订单(POST /store/order/create,入参 dto:tableId 桌号ID、contactPhone 联系电话、couponId 优惠券ID 默认 null、dinerCount 就餐人数、immediatePay 是否立即支付 默认 0、remark 备注信息 最多30字)
  72. export const PostOrderCreate = (dto) =>
  73. api.post({ url: '/store/order/create', params: dto });
  74. // 订单分页列表(GET /store/order/page,入参 current 页码、size 每页数量、orderStatus 订单状态、storeId 门店ID、tableId 桌号ID)
  75. export const GetOrderPage = (params) =>
  76. api.get({ url: '/store/order/page', params });
  77. // 我的订单(GET /store/order/my-orders,入参 current 页码、size 每页数量、type 订单类型 0未支付 1历史)
  78. export const GetMyOrders = (params) =>
  79. api.get({ url: '/store/order/my-orders', params });
  80. // 订单详情(GET /store/order/info/{orderId},入参 orderId 订单ID)
  81. export const GetOrderInfo = (orderId) =>
  82. api.get({ url: `/store/order/info/${encodeURIComponent(orderId)}` });
  83. // 订单支付(POST /payment/prePay,入参 orderNo 订单号、payType 支付类型 默认 wechatPayMininProgram、payer 支付用户 openid、price 订单金额、subject 订单标题;返回微信支付调起参数)
  84. export const PostOrderPay = (params) =>
  85. api.get({
  86. url: '/payment/prePay',
  87. params: {
  88. orderNo: params.orderNo,
  89. payType: 'wechatPayMininProgram',
  90. payer: params.payer,
  91. price: params.price,
  92. subject: params.subject ?? '订单支付'
  93. }
  94. });
  95. // 根据第三方订单号查询支付结果(GET /payment/searchOrderByOutTradeNoPath,入参 payType、transactionId)
  96. // 支付页调用时不显示全局 loading
  97. export const GetSearchOrderByOutTradeNoPath = (params) =>
  98. api.get({
  99. url: '/payment/searchOrderByOutTradeNoPath',
  100. params: {
  101. payType: params.payType ?? 'wechatPayMininProgram',
  102. transactionId: params.transactionId
  103. },
  104. loading: false
  105. });
  106. // 订单翻转/完成(POST /store/order/complete/{orderId},入参 orderId)
  107. // 支付页调用时不显示全局 loading
  108. export const PostOrderComplete = (orderId) =>
  109. api.post({ url: `/store/order/complete/${encodeURIComponent(orderId)}`, loading: false });
  110. /**
  111. * 订单 SSE 接口配置(GET /store/order/sse/{tableId})
  112. * 仅提供 URL 与 header,实际连接请使用 utils/sse.js 的 createSSEConnection 封装
  113. */
  114. export function getOrderSseConfig(tableId) {
  115. const userStore = useUserStore();
  116. return {
  117. url: `${BASE_API_URL}/store/order/sse/${encodeURIComponent(tableId)}`,
  118. header: { Authorization: userStore.getToken || '' },
  119. timeout: 0
  120. };
  121. }