forked from XiaoLFeng/XF_Index
232 lines
16 KiB
PHP
232 lines
16 KiB
PHP
<!doctype html>
|
|
<html lang="zh-CN">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta name="viewport"
|
|
content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
|
|
<meta http-equiv="X-UA-Compatible" content="ie=edge">
|
|
<link rel="stylesheet" href="{{ asset('css/app.css') }}">
|
|
<link rel="stylesheet" href="{{ asset('css/flowbite.css') }}">
|
|
@include('modules.head')
|
|
{!! $webHeader !!}
|
|
</head>
|
|
<body>
|
|
<div class="bg-white">
|
|
@include('modules.navbar')
|
|
<div class="relative isolate px-6 lg:px-8">
|
|
<div class="absolute inset-x-0 -top-40 -z-10 transform-gpu overflow-hidden blur-3xl sm:-top-80"
|
|
aria-hidden="true">
|
|
<div
|
|
class="relative left-[calc(50%-11rem)] aspect-[1155/678] w-[36.125rem] -translate-x-1/2 rotate-[30deg] bg-gradient-to-tr from-[#ff80b5] to-[#9089fc] opacity-30 sm:left-[calc(50%-30rem)] sm:w-[72.1875rem]"
|
|
style="clip-path: polygon(74.1% 44.1%, 100% 61.6%, 97.5% 26.9%, 85.5% 0.1%, 80.7% 2%, 72.5% 32.5%, 60.2% 62.4%, 52.4% 68.1%, 47.5% 58.3%, 45.2% 34.5%, 27.5% 76.7%, 0.1% 64.9%, 17.9% 100%, 27.6% 76.8%, 76.1% 97.7%, 74.1% 44.1%)"></div>
|
|
</div>
|
|
<div class="mx-auto my-10 max-w-4xl py-8 sm:py-16 lg:py-16">
|
|
<form id="FormData" action="#" onsubmit="return false" method="POST">
|
|
<div
|
|
class="col-span-10 lg:col-span-7 items-center justify-center rounded bg-gray-50 dark:bg-gray-800 shadow">
|
|
<div id="screen" class="px-10 py-5">
|
|
<h1 class="text-center mb-4 text-3xl font-bold leading-none tracking-tight text-gray-900 md:text-3xl lg:text-4xl dark:text-white mt-5">
|
|
身份验证</h1>
|
|
<p class="mb-6 text-lg font-normal text-gray-500 sm:px-16 xl:px-48 dark:text-gray-400 text-center">
|
|
您好 <b>{{ $blog->blogName }}</b> 的站长</p>
|
|
<label>
|
|
<input name="id" type="number" class="hidden" value="{{ $blog->id }}">
|
|
</label>
|
|
<div class="mb-6">
|
|
<label for="userEmail" class="block mb-2 text-sm font-medium text-gray-900 dark:text-white">
|
|
<span>邮箱验证</span>
|
|
<span class="text-gray-400 dark:text-gray-300">(邮箱提示:{{ $blog->blogOwnEmail }})</span>
|
|
<span data-tooltip-target="userEmail-Tooltip" class="bi bi-info-circle mx-1 text-blue-700"></span>
|
|
<span class="text-red-700">*</span>
|
|
</label>
|
|
<div id="userEmail-Tooltip" role="tooltip" class="absolute z-10 invisible inline-block px-3 py-2 text-sm font-medium text-white
|
|
transition-opacity duration-300 bg-gray-900 rounded-lg shadow-sm opacity-0 tooltip dark:bg-gray-700">
|
|
(请输入您在本站预留的有效邮箱)为了保证用户不会恶意收到验证邮箱,需要用户自行输入完整邮箱进行验证
|
|
<div class="tooltip-arrow" data-popper-arrow></div>
|
|
</div>
|
|
<div class="relative">
|
|
<div class="absolute inset-y-0 left-0 flex items-center pl-3 pointer-events-none">
|
|
<i class="bi bi-mailbox"></i>
|
|
</div>
|
|
<input type="email" name="userEmail" id="userEmail" placeholder="xxx@xx.xx" class="bg-white border
|
|
border-gray-300 text-gray-900 text-sm rounded-lg focus:ring-blue-500 focus:border-blue-500 block w-full pl-10 p-2.5 dark:bg-gray-700 dark:border-gray-600 dark:placeholder-gray-400 dark:text-white dark:focus:ring-blue-500 dark:focus:border-blue-500"
|
|
required>
|
|
</div>
|
|
</div>
|
|
<div class="mb-6">
|
|
<label for="userCode" class="block mb-2 text-sm font-medium text-gray-900 dark:text-white">
|
|
<span>邮箱验证码</span>
|
|
<span class="text-red-700">*</span>
|
|
</label>
|
|
<div class="relative">
|
|
<div class="absolute inset-y-0 left-0 flex items-center pl-3 pointer-events-none">
|
|
<i class="bi bi-chat-right-dots"></i>
|
|
</div>
|
|
<input type="text" name="userCode" id="userCode" placeholder="000000" class="bg-white border-gray-300
|
|
text-gray-900 text-sm rounded-lg focus:ring-blue-500 focus:border-blue-500 block w-full pl-10 p-2.5 dark:bg-gray-700 dark:border-gray-600 dark:placeholder-gray-400 dark:text-white dark:focus:ring-blue-500 dark:focus:border-blue-500"
|
|
required>
|
|
<button id="sendVerifyCode" onclick="Check.ajaxSendCode()" class="text-white absolute right-[3px] bottom-[3px] bg-blue-700 hover:bg-blue-800
|
|
focus:ring-4
|
|
focus:outline-none focus:ring-blue-300 font-medium rounded-lg text-sm px-4 py-2 dark:bg-blue-600 dark:hover:bg-blue-700
|
|
dark:focus:ring-blue-800">发送验证码
|
|
</button>
|
|
</div>
|
|
</div>
|
|
<div class="pt-6 text-center">
|
|
<button id="sendCheckCode" onclick="Check.ajaxVerifyCode()" class="focus:outline-none text-white bg-green-700 hover:bg-green-800
|
|
focus:ring-4 focus:ring-green-300
|
|
font-medium rounded-lg text-sm px-5 py-2.5 mr-2 mb-2 dark:bg-green-600 dark:hover:bg-green-700 dark:focus:ring-green-800">
|
|
<i class="bi bi-send"></i>
|
|
<span class="ps-1">验证</span>
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
<div class="mb-20"></div>
|
|
<div
|
|
class="absolute inset-x-0 top-[calc(100%-13rem)] -z-10 transform-gpu overflow-hidden blur-3xl sm:top-[calc(100%-30rem)]"
|
|
aria-hidden="true">
|
|
<div
|
|
class="relative left-[calc(50%+3rem)] aspect-[1155/678] w-[36.125rem] -translate-x-1/2 bg-gradient-to-tr from-[#ff80b5] to-[#9089fc] opacity-30 sm:left-[calc(50%+36rem)] sm:w-[72.1875rem]"
|
|
style="clip-path: polygon(74.1% 44.1%, 100% 61.6%, 97.5% 26.9%, 85.5% 0.1%, 80.7% 2%, 72.5% 32.5%, 60.2% 62.4%, 52.4% 68.1%, 47.5% 58.3%, 45.2% 34.5%, 27.5% 76.7%, 0.1% 64.9%, 17.9% 100%, 27.6% 76.8%, 76.1% 97.7%, 74.1% 44.1%)"></div>
|
|
</div>
|
|
@include('modules.footer')
|
|
</div>
|
|
</div>
|
|
<!-- Toast -->
|
|
<div id="toast"
|
|
class="z-[9999] fixed top-5 left-5 hidden items-center w-full max-w-xs p-4 space-x-4 text-gray-500 bg-white divide-x divide-gray-200 rounded-lg shadow dark:text-gray-400 dark:divide-gray-700 space-x dark:bg-gray-800"
|
|
role="alert">
|
|
<div class="pl-4 text-sm font-normal">
|
|
<span id="toast-icon" class="pe-1"><i class="bi bi-info-circle text-blue-500"></i></span>
|
|
<span id="toast-info">Message sent successfully.</span>
|
|
</div>
|
|
</div>
|
|
</body>
|
|
<script src="{{ asset('js/app.js') }}"></script>
|
|
<script src="{{ asset('js/jquery.js') }}"></script>
|
|
<script type="text/javascript">
|
|
class Check {
|
|
static ajaxSendCode() {
|
|
$.ajax({
|
|
async: true,
|
|
method: "POST",
|
|
data: $('#FormData').serialize(),
|
|
url: '{{ route('api.link.custom.blogCheck') }}',
|
|
dataType: "json",
|
|
beforeSend: function () {
|
|
$('#sendVerifyCode').prop('disabled', true);
|
|
$('#sendVerifyCode').addClass('bg-blue-800');
|
|
$('#sendVerifyCode').html('<div role="status"><svg aria-hidden="true" class="w-auto h-5 mx-5 text-gray-200 animate-spin dark:text-gray-600 ' +
|
|
'fill-blue-600" viewBox="0 0 100 101" fill="none" xmlns="http://www.w3.org/2000/svg"> <path d="M100 50.5908C100 78.2051 77.6142 100' +
|
|
'.591 50 100.591C22.3858 100.591 0 78.2051 0 50.5908C0 22.9766 22.3858 0.59082 50 0.59082C77.6142 0.59082 100 22.9766 100 50.5908ZM9' +
|
|
'.08144 50.5908C9.08144 73.1895 27.4013 91.5094 50 91.5094C72.5987 91.5094 90.9186 73.1895 90.9186 50.5908C90.9186 27.9921 72.5987 9' +
|
|
'.67226 50 9.67226C27.4013 9.67226 9.08144 27.9921 9.08144 50.5908Z" fill="currentColor"/> <path d="M93.9676 39.0409C96.393 38.4038 ' +
|
|
'97.8624 35.9116 97.0079 33.5539C95.2932 28.8227 92.871 24.3692 89.8167 20.348C85.8452 15.1192 80.8826 10.7238 75.2124 7.41289C69' +
|
|
'.5422 4.10194 63.2754 1.94025 56.7698 1.05124C51.7666 0.367541 46.6976 0.446843 41.7345 1.27873C39.2613 1.69328 37.813 4.19778 38' +
|
|
'.4501 6.62326C39.0873 9.04874 41.5694 10.4717 44.0505 10.1071C47.8511 9.54855 51.7191 9.52689 55.5402 10.0491C60.8642 10.7766 65' +
|
|
'.9928 12.5457 70.6331 15.2552C75.2735 17.9648 79.3347 21.5619 82.5849 25.841C84.9175 28.9121 86.7997 32.2913 88.1811 35.8758C89.083 ' +
|
|
'38.2158 91.5421 39.6781 93.9676 39.0409Z" fill="currentFill"/> </svg> <span class="sr-only">Loading...</span> </div>');
|
|
},
|
|
success: function (returnData) {
|
|
if (returnData.output === "Success") {
|
|
Toast.toggle('验证码发送成功', '<i class="bi bi-check-circle text-green-500"></i>');
|
|
$('#sendVerifyCode').text('已发送 (60s)');
|
|
setTimeout(function () {
|
|
$('#sendVerifyCode').prop('disabled', false);
|
|
$('#sendVerifyCode').removeClass('bg-blue-800');
|
|
}, 60000);
|
|
} else {
|
|
Toast('未知错误', '<i class="bi bi-x-circle text-red-500"></i>');
|
|
$('#sendVerifyCode').text('未知错误,请刷新');
|
|
$('#sendVerifyCode').removeClass('bg-blue-800').addClass('bg-red-700');
|
|
}
|
|
},
|
|
error: function (returnData) {
|
|
Toast.set('其他错误', '<i class="bi bi-x-circle text-red-500"></i>');
|
|
if (returnData.responseJSON.output !== 'SendingTimeTooFast') {
|
|
Toast.toggle(returnData.responseJSON.data.message, '<i class="bi bi-x-circle text-red-500"></i>')
|
|
$('#sendVerifyCode').prop('disabled', false);
|
|
$('#sendVerifyCode').removeClass('bg-blue-800');
|
|
$('#sendVerifyCode').text('发送验证码');
|
|
} else {
|
|
Toast.toggle(returnData.responseJSON.data.message + '(' + returnData.responseJSON.data.data.time + 's)', '<i class="bi bi-x-circle ' +
|
|
'text-red-500"></i>');
|
|
$('#sendVerifyCode').text('已发送 (' + returnData.responseJSON.data.data.time + 's)');
|
|
setTimeout(function () {
|
|
$('#sendVerifyCode').prop('disabled', false);
|
|
$('#sendVerifyCode').removeClass('bg-blue-800');
|
|
}, returnData.responseJSON.data.data.time*1000);
|
|
}
|
|
}
|
|
});
|
|
}
|
|
|
|
static ajaxVerifyCode() {
|
|
$.ajax({
|
|
async: true,
|
|
method: "POST",
|
|
data: $('#FormData').serialize(),
|
|
url: '{{ route('api.link.custom.blogVerify') }}',
|
|
dataType: "json",
|
|
beforeSend: function () {
|
|
$('#sendCheckCode').html('<div role="status"><svg aria-hidden="true" class="w-auto h-5 mx-5 text-gray-200 animate-spin dark:text-gray-600 ' +
|
|
'fill-blue-600" viewBox="0 0 100 101" fill="none" xmlns="http://www.w3.org/2000/svg"> <path d="M100 50.5908C100 78.2051 77.6142 100' +
|
|
'.591 50 100.591C22.3858 100.591 0 78.2051 0 50.5908C0 22.9766 22.3858 0.59082 50 0.59082C77.6142 0.59082 100 22.9766 100 50.5908ZM9' +
|
|
'.08144 50.5908C9.08144 73.1895 27.4013 91.5094 50 91.5094C72.5987 91.5094 90.9186 73.1895 90.9186 50.5908C90.9186 27.9921 72.5987 9' +
|
|
'.67226 50 9.67226C27.4013 9.67226 9.08144 27.9921 9.08144 50.5908Z" fill="currentColor"/> <path d="M93.9676 39.0409C96.393 38.4038 ' +
|
|
'97.8624 35.9116 97.0079 33.5539C95.2932 28.8227 92.871 24.3692 89.8167 20.348C85.8452 15.1192 80.8826 10.7238 75.2124 7.41289C69' +
|
|
'.5422 4.10194 63.2754 1.94025 56.7698 1.05124C51.7666 0.367541 46.6976 0.446843 41.7345 1.27873C39.2613 1.69328 37.813 4.19778 38' +
|
|
'.4501 6.62326C39.0873 9.04874 41.5694 10.4717 44.0505 10.1071C47.8511 9.54855 51.7191 9.52689 55.5402 10.0491C60.8642 10.7766 65' +
|
|
'.9928 12.5457 70.6331 15.2552C75.2735 17.9648 79.3347 21.5619 82.5849 25.841C84.9175 28.9121 86.7997 32.2913 88.1811 35.8758C89.083 ' +
|
|
'38.2158 91.5421 39.6781 93.9676 39.0409Z" fill="currentFill"/> </svg> <span class="sr-only">Loading...</span> </div>');
|
|
},
|
|
success: function (returnData) {
|
|
if (returnData.output === "Success") {
|
|
Toast.toggle(returnData.data.message, '<i class="bi bi-check-circle text-green-500"></i>');
|
|
$('#sendCheckCode').prop('disabled', true);
|
|
$('#sendCheckCode').removeClass('bg-green-700').addClass('bg-green-800');
|
|
$('#sendCheckCode').html('<i class="bi bi-check-circle"></i><span class="ps-1">验证通过</span>');
|
|
|
|
setTimeout(function () {
|
|
location.href = '{{ route('function.edit-friend','') }}/' + returnData.data.id
|
|
}, 3000);
|
|
} else {
|
|
Toast('未知错误', '<i class="bi bi-x-circle text-red-500"></i>');
|
|
$('#sendCheckCode').text('未知错误,请刷新');
|
|
$('#sendCheckCode').removeClass('bg-blue-800').addClass('bg-red-700');
|
|
}
|
|
},
|
|
error: function (returnData) {
|
|
Toast.set('其他错误', '<i class="bi bi-x-circle text-red-500"></i>');
|
|
if (returnData.responseJSON.output !== 'SendingTimeTooFast') {
|
|
Toast.toggle(returnData.responseJSON.data.message, '<i class="bi bi-x-circle text-red-500"></i>');
|
|
$('#sendCheckCode').prop('disabled', false);
|
|
$('#sendCheckCode').html('<i class="bi bi-send"></i><span class="ps-1">验证</span>');
|
|
}
|
|
}
|
|
});
|
|
}
|
|
}
|
|
|
|
// 处理Toast
|
|
class Toast {
|
|
static toggle(data, icon) {
|
|
this.set(data, icon);
|
|
$('#toast').fadeIn(300);
|
|
setTimeout(function () {
|
|
$('#toast').fadeOut(300);
|
|
}, 3000);
|
|
}
|
|
|
|
static set(data, icon) {
|
|
$('#toast-icon').html(icon);
|
|
$('#toast-info').text(data);
|
|
}
|
|
}
|
|
</script>
|
|
{!! $webFooter !!}
|
|
</html>
|