TwoStepCaptcha.vue 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. <template>
  2. <!-- 两步验证 -->
  3. <a-modal
  4. centered
  5. v-model="visible"
  6. @cancel="handleCancel"
  7. :maskClosable="false"
  8. >
  9. <div slot="title" :style="{ textAlign: 'center' }">两步验证</div>
  10. <template slot="footer">
  11. <div :style="{ textAlign: 'center' }">
  12. <a-button key="back" @click="visible = false">返回</a-button>
  13. <a-button key="submit" type="primary" :loading="stepLoading" @click="handleStepOk">
  14. 继续
  15. </a-button>
  16. </div>
  17. </template>
  18. <a-spin :spinning="stepLoading">
  19. <a-form layout="vertical" :auto-form-create="(form)=>{this.form = form}">
  20. <p style="text-align: center" v-if="!stepLoading">请在手机中打开 Google Authenticator 或两步验证 APP<br />输入 6 位动态码</p>
  21. <p style="text-align: center" v-else>正在验证..<br/>请稍后</p>
  22. <a-form-item
  23. :style="{ textAlign: 'center' }"
  24. hasFeedback
  25. fieldDecoratorId="stepCode"
  26. :fieldDecoratorOptions="{rules: [{ required: true, message: '请输入 6 位动态码!', pattern: /^\d{6}$/, len: 6 }]}"
  27. >
  28. <a-input :style="{ textAlign: 'center' }" @keyup.enter.native="handleStepOk" placeholder="000000" />
  29. </a-form-item>
  30. <p style="text-align: center">
  31. <a @click="onForgeStepCode">遗失手机?</a>
  32. </p>
  33. </a-form>
  34. </a-spin>
  35. </a-modal>
  36. </template>
  37. <script>
  38. export default {
  39. props: {
  40. visible: {
  41. type: Boolean,
  42. default: false
  43. }
  44. },
  45. data() {
  46. return {
  47. stepLoading: false,
  48. form: null
  49. };
  50. },
  51. methods: {
  52. handleStepOk() {
  53. const vm = this
  54. this.stepLoading = true
  55. this.form.validateFields((err, values) => {
  56. if (!err) {
  57. console.log('values', values)
  58. setTimeout( () => {
  59. vm.stepLoading = false
  60. vm.$emit('success', { values })
  61. }, 2000)
  62. return;
  63. }
  64. this.stepLoading = false
  65. this.$emit('error', { err })
  66. })
  67. },
  68. handleCancel () {
  69. },
  70. onForgeStepCode() {
  71. }
  72. }
  73. };
  74. </script>