Cashier 收银台
业务支付弹窗,支持支付渠道选择和支付验证码发送
引入
import { Cashier } from 'mand-mobile'
Vue.component(Cashier.name, Cashier)
代码演示
基本
<template>
<div class="md-example-child md-example-child-cashier">
<md-field
title="支付结果"
>
<md-radio
v-model="cashierResult"
:options="cashierResults"
></md-radio>
</md-field>
<md-field
title="支付配置"
>
<md-input-item
title="支付金额"
align="right"
type="money"
v-model="cashierAmount"
>
</md-input-item>
<md-field-item
title="发送验证码"
align="right"
>
<md-switch v-model="isCashierCaptcha"></md-switch>
</md-field-item>
</md-field>
<md-button @click="isCashierhow = !isCashierhow">{{ isCashierhow ? '收起收银台' : '唤起收银台' }}</md-button>
<md-cashier
ref="cashier"
v-model="isCashierhow"
:channels="cashierChannels"
:payment-amount="cashierAmount"
payment-describe="关于支付金额的特殊说明"
@select="onCashierSelect"
@pay="onCashierPay"
@cancel="onCashierCancel"
></md-cashier>
</div>
</template>
<script>
import {Button, Radio, Field, FieldItem, InputItem, Switch, Cashier, Toast} from 'mand-mobile'
export default {
name: 'cashier-demo',
components: {
[Button.name]: Button,
[Radio.name]: Radio,
[Field.name]: Field,
[FieldItem.name]: FieldItem,
[InputItem.name]: InputItem,
[Switch.name]: Switch,
[Cashier.name]: Cashier,
},
data() {
return {
isCashierhow: false,
isCashierCaptcha: false,
cashierAmount: '100.00',
cashierResult: 'success',
cashierResults: [
{
text: '支付成功',
value: 'success',
},
{
text: '支付失败',
value: 'fail',
},
],
cashierChannels: [
{
icon: 'cashier-icon-1',
text: '招商银行储蓄卡(0056)支付',
value: '001',
},
{
icon: 'cashier-icon-2',
text: '支付宝支付',
value: '002',
},
{
icon: 'cashier-icon-3',
text: '微信支付',
value: '003',
},
{
icon: 'cashier-icon-4',
text: 'QQ钱包支付',
value: '004',
},
{
icon: 'cashier-icon-5',
text: '一网通支付',
value: '005',
},
],
}
},
computed: {
cashier() {
return this.$refs.cashier
},
},
methods: {
doPay() {
if (this.isCashierCaptcha) {
this.cashier.next('captcha', {
text: 'Verification code sent to 156 **** 8965',
autoCountdown: false,
countNormalText: 'Send Verification code',
countActiveText: 'Retransmission after {$1}s',
onSend: countdown => {
console.log('[Mand Mobile] Send Captcha')
this.sendCaptcha().then(() => {
countdown()
})
},
onSubmit: code => {
console.log(`[Mand Mobile] Send Submit ${code}`)
this.checkCaptcha(code).then(res => {
if (res) {
this.createPay().then(() => {
this.cashier.next(this.cashierResult)
})
}
})
},
})
} else {
this.createPay().then(() => {
this.cashier.next(this.cashierResult, {
buttonText: '好的',
handler: () => {
Toast.info(`${this.cashierResult}点击`)
},
})
})
}
},
// Create a pay request & check pay result
createPay() {
this.cashier.next('loading')
return new Promise(resolve => {
this.timer = setTimeout(() => {
resolve()
}, 3000)
})
},
// Create a captcha sending request
sendCaptcha() {
return new Promise(resolve => {
this.timer = setTimeout(() => {
resolve()
}, 200)
})
},
// Create a captcha checking request
checkCaptcha(code) {
return new Promise(resolve => {
this.timer = setTimeout(() => {
resolve(!!code)
}, 200)
})
},
onCashierSelect(item) {
console.log(`[Mand Mobile] Select ${JSON.stringify(item)}`)
},
onCashierPay(item) {
console.log(`[Mand Mobile] Pay ${JSON.stringify(item)}`)
this.doPay()
},
onCashierCancel() {
// Abort pay request or checking request
this.timer && clearTimeout(this.timer)
},
},
}
</script>
<style lang="stylus">
.md-example-child-cashier
.md-field
margin-bottom 30px
.choose-channel-item
.item-icon.cashier-icon-1
background url('') center no-repeat
background-size 26px
.item-icon.cashier-icon-2
background url('') center no-repeat
background-size 26px
.item-icon.cashier-icon-3
background url('') center no-repeat
background-size 26px
.item-icon.cashier-icon-4
background url('') center no-repeat
background-size 26px
.item-icon.cashier-icon-5
background url('') center no-repeat
background-size 26px
</style>
API
Cashier Props
属性 | 说明 | 类型 | 默认值 | 备注 |
---|---|---|---|---|
v-model | 收银台是否显示 | Boolean | false | - |
channels | 支付渠道数据源 | Array<{text, value, icon}> | [] | icon 可作为className 或组件Icon 的name 属性 |
default-index | 默认选中支付渠道索引 | Number | 0 | - |
title | 收银台弹窗标题 | String | 支付 | - |
payment-title | 支付金额标题 | String | 支付金额 | 支持html fragment |
payment-amount | 支付金额 | String | 0.00 | 支持html fragment |
payment-describe | 支付金额说明 | String | - | 支持html fragment |
pay-button-text1.3.1+ | 确认支付按钮文案 | String | 确认支付 | 支持html fragment |
more-button-text1.3.1+ | 更多支付渠道按钮文案 | String | 更多支付方式 | 支持html fragment |
Cashier Methods
next(scene, option)
进入收银台下一步
参数 | 说明 | 类型 | 默认值 | 备注 |
---|---|---|---|---|
scene | 步骤标识, 'captcha(发送验证码)', 'loading(支付中)', 'success(支付成功)', 'fail(支付失败)' | String | - | - |
option | 当前步骤配置 | Object | 属性如下所示 | - |
captcha
option属性 说明 类型 默认值 备注 text 发送验证码说明 String - 支持 html fragment
maxlength 验证码位数 Number 4
若为 -1
则不限制输入长度count 验证码重新发送倒计时 Number 60
若为 0
则不显示重新发送auto-countdown 是否自动开始倒计时,否则需手动调用 countdown
Boolean true
- countNormalText1.3.0+ 发送验证码正常状态文字 String 发送验证码
- countActiveText1.3.0+ 发送验证码及倒计时按钮文案配置项 String {$1}秒后重发
- onSend 验证码发送回调 Function(countdown: Function) - countdown
为开始倒计时方法onSubmit 验证码提交回调 Function(code: String) - code
为输入的验证码loading
option属性 说明 类型 默认值 备注 text 支付中说明 String 支付结果查询中…
支持 html fragment
success
option属性 说明 类型 默认值 备注 text 支付成功说明 String 支付成功
支持 html fragment
buttonText1.3.1+ 按钮文案 String 我知道了
支持 html fragment
handler 按钮点击回调 Function - - fail
option属性 说明 类型 默认值 备注 text 支付失败说明 String 支付失败,请稍后重试
支持 html fragment
buttonText1.3.1+ 按钮文案 String 我知道了
支持 html fragment
handler 按钮点击回调 Function - -
Cashier Events
@select(item: {text, value})
支付渠道选中事件
@pay(item: {text, value})
支付渠道确认并发起支付事件
@cancel()
取消支付事件
@show()
收银台弹窗展示事件
@hide()
收银台弹窗隐藏事件