# GlobalPayment

全球收银对象 GlobalPayment

# 属性

# string methodKey

初始值为null。当开发者调用 openMethodPicker 用户选中具体支付方式后确定,后续不再改变。


const goods = {
  goods_id: `goods_1`,
  goods_name: `拿铁`,
  goods_unit_price: {
    currency: 'SGD',
    total: 10,
  },
  goods_quantity: '1',
  goods_category: '1',
}

const globalPay = async () => {
  if (typeof wx.createGlobalPayment !== 'function') {
    // 基础库版本不支持
    // 方案一、微信支付做兜底
    wx.requestPayment({
      timeStamp: '',
      nonceStr: '',
      package: '',
      signType: '',
      paySign: '',
    })
    // 方案二、引导用户更新
    // 方案三、mp后台设置最低基础库版本 3.7.3
    return
  }

  const payment = wx.createGlobalPayment({ mchRegion: 'SG', isSandbox: true })

  try {
    const pickerResp = await payment.openMethodPicker({
      amount: goods.goods_unit_price,
    })

    console.log(`openMethodPicker resp: `, pickerResp)

    if (pickerResp.methodKey === 'WECHAT_PAY') {
      // 发起微信支付
    } else {
      // 后台接口发起预下单
      const preOrderResp = await preOrder(
        goods.goods_unit_price,
        [goods],
        pickerResp.methodKey
      )

      console.log(`preOrder resp: `, preOrderResp)

      const { payment_id, prepay_info } = preOrderResp

      const requestPaymentResp = await payment.requestGlobalPayment({
        paymentId: payment_id,
        prepayInfo: prepay_info,
      })

      console.log(`requestGlobalPayment resp: `, requestPaymentResp)
    }
  } catch (error) {
    console.log(error)
  }
}

# 方法

# Promise GlobalPayment.openMethodPicker(Object object)

拉起全球收银的支付方式选择面板。当用户选择支付方式或者关闭选择面板后,返回相应结果。 当用户选定支付方式后,globalPayment上的属性 methodKey 也会更新,后续该对象再次调用将直接失败,不再拉起选择面板。 若用户选择微信支付,请开发者按原微信支付接口 wx.requestPayment 调用完成后续支付流程。 若用户选择TPG的支付方式,流程会等待开发者前往TPG完成预下单后,携带预支付信息和交易单号调用 requestGlobalPayment,若开发者超时未调用,则会提示用户加载超时(超时时间暂定为30s)。 当用户关闭选择面板,即未选择支付方式,开发者后续仍可继续调用接口拉起支付方式选择面板。

# Promise GlobalPayment.requestGlobalPayment(Object object)

开发者调用 openMethodPicker 并在返回值 methodKey 中接受到用户选择了TPG的支付方式后,可调用此接口接入TPG的支付流程。 当用户已成功完成当前订单支付后,再次调用该对象的 requestGlobalPayment 会失败。即每次支付都需创建新的 globalPayment 对象重走流程。 仅在 methodKey 为TPG支付类型才能进入全球收银的支付流程,其他情况会失败。 建议在接口返回后,不论成功或失败,均通过 TPG 接口 inquiry-payment 对订单状态进行查询。

# Promise GlobalPayment.abort()

用户选择TPG的支付方式,界面会进入加载的Toast,等待开发者前往TPG完成预下单后携带预支付信息和交易单号调用 requestGlobalPayment,若开发者在 TPG预下单未成功或出现异常情况,可调用该接口主动终止TPG支付流程,界面加载的Toast将会隐藏,提示用户下单失败。