mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			90 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			90 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
|   <!-- 两步验证 -->
 | |
|   <a-modal
 | |
|     centered
 | |
|     v-model="visible"
 | |
|     @cancel="handleCancel"
 | |
|     :maskClosable="false"
 | |
|   >
 | |
|     <div slot="title" :style="{ textAlign: 'center' }">两步验证</div>
 | |
|     <template slot="footer">
 | |
|       <div :style="{ textAlign: 'center' }">
 | |
|         <a-button key="back" @click="handleCancel">返回</a-button>
 | |
|         <a-button key="submit" type="primary" :loading="stepLoading" @click="handleStepOk">
 | |
|           继续
 | |
|         </a-button>
 | |
|       </div>
 | |
|     </template>
 | |
| 
 | |
|     <a-spin :spinning="stepLoading">
 | |
|       <a-form layout="vertical" :auto-form-create="(form)=>{this.form = form}">
 | |
|         <div class="step-form-wrapper">
 | |
|           <p style="text-align: center" v-if="!stepLoading">请在手机中打开 Google Authenticator 或两步验证 APP<br />输入 6 位动态码</p>
 | |
|           <p style="text-align: center" v-else>正在验证..<br/>请稍后</p>
 | |
|           <a-form-item
 | |
|             :style="{ textAlign: 'center' }"
 | |
|             hasFeedback
 | |
|             fieldDecoratorId="stepCode"
 | |
|             :fieldDecoratorOptions="{rules: [{ required: true, message: '请输入 6 位动态码!', pattern: /^\d{6}$/, len: 6 }]}"
 | |
|           >
 | |
|             <a-input :style="{ textAlign: 'center' }" @keyup.enter.native="handleStepOk" placeholder="000000" />
 | |
|           </a-form-item>
 | |
|           <p style="text-align: center">
 | |
|             <a @click="onForgeStepCode">遗失手机?</a>
 | |
|           </p>
 | |
|         </div>
 | |
|       </a-form>
 | |
|     </a-spin>
 | |
|   </a-modal>
 | |
| </template>
 | |
| 
 | |
| <script>
 | |
| export default {
 | |
|   props: {
 | |
|     visible: {
 | |
|       type: Boolean,
 | |
|       default: false
 | |
|     }
 | |
|   },
 | |
|   data () {
 | |
|     return {
 | |
|       stepLoading: false,
 | |
| 
 | |
|       form: null
 | |
|     }
 | |
|   },
 | |
|   methods: {
 | |
|     handleStepOk () {
 | |
|       const vm = this
 | |
|       this.stepLoading = true
 | |
|       this.form.validateFields((err, values) => {
 | |
|         if (!err) {
 | |
|           console.log('values', values)
 | |
|           setTimeout(() => {
 | |
|             vm.stepLoading = false
 | |
|             vm.$emit('success', { values })
 | |
|           }, 2000)
 | |
|           return
 | |
|         }
 | |
|         this.stepLoading = false
 | |
|         this.$emit('error', { err })
 | |
|       })
 | |
|     },
 | |
|     handleCancel () {
 | |
|       this.visible = false
 | |
|       this.$emit('cancel')
 | |
|     },
 | |
|     onForgeStepCode () {
 | |
| 
 | |
|     }
 | |
|   }
 | |
| }
 | |
| </script>
 | |
| <style lang="less" scoped>
 | |
|   .step-form-wrapper {
 | |
|     margin: 0 auto;
 | |
|     width: 80%;
 | |
|     max-width: 400px;
 | |
|   }
 | |
| </style>
 |