| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299 |
- import PageContainerBehavior from "../../../../core/behavior/page-container.behavior";
- import tickleBehavior, {
- getTickleContext,
- } from "../../../../core/behavior/tickle.behavior";
- import {
- orderListMethod,
- orderCancelMethod,
- orderPayMethod,
- } from "../../request";
- // module/article/pages/order-list/order-list.ts
- Page({
- behaviors: [PageContainerBehavior, tickleBehavior],
- properties: {},
- data: {
- showConfirm: false,
- currentTab: "all", // 当前选中的标签
- orders: [],
- filteredOrders: [], // 用于存储过滤后的订单
- patientId: 0,
- id: "",
- statusObj: {
- 0: "待付款",
- 6: "待收货",
- 345: "交易成功",
- 2: "交易关闭",
- },
- statusClassObj: {
- 0: "status-pending",
- 6: "status-received",
- 345: "status-completed",
- 2: "status-closed",
- },
- selectedAddress: null,
- paying: false,
- payingId: '',
- showAddress: false,
- // 节流控制
- throttleTimers: {} as Record<string, boolean>, // 存储各个按钮的节流定时器
- },
- computed: {},
- // 节流函数 - 防止短时间内重复点击
- throttle(func: Function, delay: number = 1000, key: string = "default") {
- return (...args: any[]) => {
- // 如果该按钮正在节流中,直接返回
- if (this.data.throttleTimers[key]) {
- console.log(`按钮 ${key} 正在节流中,忽略点击`);
- return;
- }
- // 设置节流定时器
- this.setData({
- [`throttleTimers.${key}`]: true,
- });
- // 执行函数
- const result = func.apply(this, args);
- // 延迟清除节流状态
- setTimeout(() => {
- this.setData({
- [`throttleTimers.${key}`]: false,
- });
- }, delay);
- return result;
- };
- },
- onLoad(options: any) {
- // 读取 tab 参数,默认为 all
- console.log(options, "options");
- const tab = options?.tab || "all";
- this.setData({ currentTab: tab });
- // this.filterOrdersList(tab);
- },
- onShow() {
- this.filterOrdersList(this.data.currentTab);
- // 读取地址
- // if (JSON.stringify(this.data.selectedAddress) !== "{}") {
- // this.setData({
- // name: this.data.selectedAddress?.liaison,
- // phone: this.data.selectedAddress?.phone,
- // address: this.data.selectedAddress?.fullAddress,
- // });
- // }
- },
- // 切换tab
- onTabChange(event: any) {
- const type = event.detail.value;
- console.log(type, "传来的type");
- this.setData({ currentTab: type });
- this.filterOrdersList(type);
- },
- // 获取列表数据
- async getOrderList(progress: string) {
- const patientId = wx.getStorageSync("patientId");
- if (!patientId) {
- getTickleContext.call(this).showWarnMessage("请先登录");
- return;
- }
- const res = await orderListMethod(patientId, progress);
- if (res && res.data) {
- res.data.forEach((item: any) => {
- item.address = `${item.provinceName}${item.cityName}${item.areaName}${item.detailAddress}`;
- item.liaison =
- item.liaison !== null && item.liaison !== undefined
- ? item.liaison
- : "";
- item.phone =
- item.phone !== null && item.phone !== undefined ? item.phone : "";
- if (
- !item.provinceName ||
- !item.cityName ||
- !item.areaName ||
- !item.detailAddress ||
- !item.liaison ||
- !item.phone
- ) {
- item.showAddress = false;
- } else {
- item.showAddress = true;
- }
- });
- this.setData({ orders: res.data });
- }
- },
- // 过滤订单l列表
- filterOrdersList(type: any) {
- // 根据当前选中的标签过滤订单
- console.log(type, "根据传来的type获取不同状态下的列表");
- switch (type) {
- // 全部订单
- case "all":
- this.getOrderList("");
- break;
- // 待付款订单
- case "pending":
- this.getOrderList("0");
- break;
- // 待收货订单
- case "received":
- this.getOrderList("6");
- break;
- // 交易完成订单
- case "completed":
- this.getOrderList("345");
- break;
- default:
- break;
- }
- },
- // 订单支付
- onPay: function (event: any) {
- return this.throttle(
- async (e: any) => {
- const orderId = e.currentTarget.dataset.id;
- if (this.data.payingId) return; // 防重复
- this.setData({ paying: true, payingId: orderId });
- try {
- await orderPayMethod(orderId);
- wx.navigateTo({
- url: "/module/article/pages/success-page/success-page?title=订单支付成功",
- });
- } catch (error: any) {
- this.setData({ paying: false, payingId: '' });
- // getTickleContext.call(this).showWarnMessage(error.errMsg);
- wx.showToast({
- title: error.errMsg,
- icon: "none",
- });
- } finally {
- this.setData({ paying: false, payingId: '' });
- }
- },
- 2000,
- "pay"
- )(event);
- },
- // 查看物流
- onSeeLogistics: function (e: any) {
- return this.throttle(
- (event: any) => {
- console.log(event, "查看物流");
- wx.showToast({
- title: "暂未开通",
- icon: "none",
- });
- // const id = event.currentTarget.dataset.id;
- // wx.navigateTo({
- // url: `/module/article/pages/see-logistics/see-logistics?id=${id}`,
- // });
- },
- 2000,
- "logistics"
- )(e);
- },
- // 切换地址
- changeAddress: function (e: any) {
- return this.throttle(
- (event: any) => {
- const orderStatus = event.currentTarget.dataset.status;
- const id = event.currentTarget.dataset.id;
- console.log(orderStatus, "切换地址");
- // 根据订单状态判断是否可以切换地址. 待支付状态下可以切换地址
- if (orderStatus === "0") {
- wx.navigateTo({
- url:
- "/module/article/pages/manage-address/manage-address?type=orderList&orderId=" +
- id,
- });
- }
- },
- 2000,
- "changeAddress"
- )(e);
- },
- // 打开取消订单弹窗
- onCancel: function (event: any) {
- return this.throttle(
- (e: any) => {
- const orderId = e.currentTarget.dataset.id;
- // 处理订单取消逻辑
- this.setData({ id: orderId });
- this.setData({ showConfirm: true });
- },
- 2000,
- "cancel"
- )(event);
- },
- // 取消订单
- async cancelOrder(id: string) {
- this.setData({ showConfirm: true });
- try {
- await orderCancelMethod(id);
- /* 取消订单逻辑 */
- this.setData({ showConfirm: false });
- wx.navigateTo({
- url: "/module/article/pages/success-page/success-page?title=订单取消成功",
- });
- } catch (error: any) {
- getTickleContext.call(this).showWarnMessage(error.errMsg);
- }
- },
- // 确认取消订单
- confirmCancelDialog() {
- this.cancelOrder(this.data.id);
- },
- // 关闭取消订单弹窗
- closeDialog() {
- this.setData({ showConfirm: false });
- },
- // 确认收货
- onConfirmReceiving: function (e: any) {
- return this.throttle(
- (event: any) => {
- console.log(event, "确认收货");
- const orderId = event.currentTarget.dataset.id;
- wx.navigateTo({
- url: `/module/article/pages/confirm-receiving/confirm-receiving?orderId=${orderId}`,
- });
- },
- 2000,
- "confirmReceiving"
- )(e);
- },
- // 切换地址
- onChangeAddress(e: any) {
- const orderId = e.currentTarget.dataset.id;
- // 打开地址选择器,选择后更新对应订单的地址
- // 伪代码
- wx.chooseAddress({
- success: (res) => {
- // 假设你有 orders 数组
- const idx = this.data.orders.findIndex(
- (o: any) => o.orderId === orderId
- );
- if (idx !== -1) {
- this.setData({
- [`orders[${idx}].address`]: res.detailInfo,
- });
- }
- },
- });
- },
- // 订单详情
- onOrderDetail(e: any) {
- const id = e.currentTarget.dataset.id;
- // const status = e.currentTarget.dataset.status;
- wx.navigateTo({
- url: `/module/article/pages/order-detail/order-detail?id=${id}`,
- });
- },
- //回到我的页面
- goMine() {
- console.log("goMine");
- wx.redirectTo({
- url: "/pages/mine/mine",
- });
- }
- });
|