ae39eab6108a4d337f53ad634813148dd5df1a47.svn-base 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  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="handleCancel">返回</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. <div class="step-form-wrapper">
  21. <p style="text-align: center" v-if="!stepLoading">请在手机中打开 Google Authenticator 或两步验证 APP<br />输入 6 位动态码</p>
  22. <p style="text-align: center" v-else>正在验证..<br/>请稍后</p>
  23. <a-form-item
  24. :style="{ textAlign: 'center' }"
  25. hasFeedback
  26. fieldDecoratorId="stepCode"
  27. :fieldDecoratorOptions="{rules: [{ required: true, message: '请输入 6 位动态码!', pattern: /^\d{6}$/, len: 6 }]}"
  28. >
  29. <a-input :style="{ textAlign: 'center' }" @keyup.enter.native="handleStepOk" placeholder="000000" />
  30. </a-form-item>
  31. <p style="text-align: center">
  32. <a @click="onForgeStepCode">遗失手机?</a>
  33. </p>
  34. </div>
  35. </a-form>
  36. </a-spin>
  37. </a-modal>
  38. </template>
  39. <script>
  40. export default {
  41. props: {
  42. visible: {
  43. type: Boolean,
  44. default: false
  45. }
  46. },
  47. data() {
  48. return {
  49. stepLoading: false,
  50. form: null
  51. };
  52. },
  53. methods: {
  54. handleStepOk() {
  55. const vm = this
  56. this.stepLoading = true
  57. this.form.validateFields((err, values) => {
  58. if (!err) {
  59. console.log('values', values)
  60. setTimeout( () => {
  61. vm.stepLoading = false
  62. vm.$emit('success', { values })
  63. }, 2000)
  64. return;
  65. }
  66. this.stepLoading = false
  67. this.$emit('error', { err })
  68. })
  69. },
  70. handleCancel () {
  71. this.visible = false
  72. this.$emit('cancel')
  73. },
  74. onForgeStepCode() {
  75. }
  76. }
  77. };
  78. </script>
  79. <style lang="less" scoped>
  80. .step-form-wrapper {
  81. margin: 0 auto;
  82. width: 80%;
  83. max-width: 400px;
  84. }
  85. </style>