<template>
|
<PageWrapper title="拖动校验示例">
|
<div class="flex justify-center p-4 items-center bg-gray-700">
|
<BasicDragVerify ref="el1" @success="handleSuccess" />
|
<a-button type="primary" class="ml-2" @click="handleBtnClick(el1)"> 还原 </a-button>
|
</div>
|
|
<div class="flex justify-center p-4 items-center bg-gray-700">
|
<BasicDragVerify ref="el2" @success="handleSuccess" circle />
|
<a-button type="primary" class="ml-2" @click="handleBtnClick(el2)"> 还原 </a-button>
|
</div>
|
|
<div class="flex justify-center p-4 items-center bg-gray-700">
|
<BasicDragVerify
|
ref="el3"
|
@success="handleSuccess"
|
text="拖动以进行校验"
|
successText="校验成功"
|
:barStyle="{
|
backgroundColor: '#018ffb',
|
}"
|
/>
|
<a-button type="primary" class="ml-2" @click="handleBtnClick(el3)"> 还原 </a-button>
|
</div>
|
|
<div class="flex justify-center p-4 items-center bg-gray-700">
|
<BasicDragVerify ref="el4" @success="handleSuccess">
|
<template #actionIcon="isPassing">
|
<BugOutlined v-if="isPassing" />
|
<RightOutlined v-else />
|
</template>
|
</BasicDragVerify>
|
<a-button type="primary" class="ml-2" @click="handleBtnClick(el4)"> 还原 </a-button>
|
</div>
|
|
<div class="flex justify-center p-4 items-center bg-gray-700">
|
<BasicDragVerify ref="el5" @success="handleSuccess">
|
<template #text="isPassing">
|
<div v-if="isPassing">
|
<BugOutlined />
|
成功
|
</div>
|
<div v-else>
|
拖动
|
<RightOutlined />
|
</div>
|
</template>
|
</BasicDragVerify>
|
<a-button type="primary" class="ml-2" @click="handleBtnClick(el5)"> 还原 </a-button>
|
</div>
|
</PageWrapper>
|
</template>
|
<script lang="ts" setup>
|
import { ref } from 'vue';
|
import { BasicDragVerify, DragVerifyActionType, PassingData } from '@/components/Verify';
|
import { useMessage } from '@/hooks/web/useMessage';
|
import { BugOutlined, RightOutlined } from '@ant-design/icons-vue';
|
import { PageWrapper } from '@/components/Page';
|
import { type Nullable } from '@vben/types';
|
|
const { createMessage } = useMessage();
|
const el1 = ref<Nullable<DragVerifyActionType>>(null);
|
const el2 = ref<Nullable<DragVerifyActionType>>(null);
|
const el3 = ref<Nullable<DragVerifyActionType>>(null);
|
const el4 = ref<Nullable<DragVerifyActionType>>(null);
|
const el5 = ref<Nullable<DragVerifyActionType>>(null);
|
|
function handleSuccess(data: PassingData) {
|
const { time } = data;
|
createMessage.success(`校验成功,耗时${time}秒`);
|
}
|
|
function handleBtnClick(elRef: Nullable<DragVerifyActionType>) {
|
if (!elRef) {
|
return;
|
}
|
elRef.resume();
|
}
|
</script>
|