mirror of
https://gitee.com/nocobase/nocobase.git
synced 2025-05-09 15:39:24 +08:00
* fix: add license code * fix: bug * fix: bug * fix: upgrade * fix: improve * chore: add copyright information to the file header * fix: d.ts bug * fix: bug * fix: e2e bug * fix: merge main --------- Co-authored-by: chenos <chenlinxh@gmail.com>
73 lines
2.0 KiB
TypeScript
73 lines
2.0 KiB
TypeScript
/**
|
|
* This file is part of the NocoBase (R) project.
|
|
* Copyright (c) 2020-2024 NocoBase Co., Ltd.
|
|
* Authors: NocoBase Team.
|
|
*
|
|
* This project is dual-licensed under AGPL-3.0 and NocoBase Commercial License.
|
|
* For more information, please refer to: https://www.nocobase.com/agreement.
|
|
*/
|
|
|
|
import { useTranslation } from 'react-i18next';
|
|
import { css } from '@emotion/css';
|
|
import { useAPIClient } from '../api-client';
|
|
import { useForm } from '@formily/react';
|
|
import { useEffect, useRef, useState } from 'react';
|
|
import { Button, Input, message } from 'antd';
|
|
import React from 'react';
|
|
|
|
export default function VerificationCode({ targetFieldName = 'phone', actionType, value, onChange }) {
|
|
const { t } = useTranslation();
|
|
const api = useAPIClient();
|
|
const form = useForm();
|
|
|
|
const [count, setCountdown] = useState<number>(0);
|
|
const timer = useRef(null);
|
|
|
|
useEffect(() => {
|
|
if (count <= 0 && timer.current) {
|
|
clearInterval(timer.current);
|
|
}
|
|
}, [count]);
|
|
|
|
async function onGetCode() {
|
|
if (count > 0) {
|
|
return;
|
|
}
|
|
try {
|
|
const {
|
|
data: { data },
|
|
} = await api.resource('verifications').create({
|
|
values: {
|
|
type: actionType,
|
|
phone: form.values[targetFieldName],
|
|
},
|
|
});
|
|
message.success(t('Operation succeeded'));
|
|
if (value) {
|
|
onChange('');
|
|
}
|
|
const expiresIn = data.expiresAt ? Math.ceil((Date.parse(data.expiresAt) - Date.now()) / 1000) : 60;
|
|
setCountdown(expiresIn);
|
|
timer.current = setInterval(() => {
|
|
setCountdown((count) => count - 1);
|
|
}, 1000);
|
|
} catch (err) {
|
|
console.error(err);
|
|
}
|
|
}
|
|
|
|
return (
|
|
<fieldset
|
|
className={css`
|
|
display: flex;
|
|
gap: 0.5em;
|
|
`}
|
|
>
|
|
<Input value={value} onChange={onChange} placeholder={t('Verification code')} />
|
|
<Button onClick={onGetCode} disabled={count > 0}>
|
|
{count > 0 ? t('Retry after {{count}} seconds', { count }) : t('Send code')}
|
|
</Button>
|
|
</fieldset>
|
|
);
|
|
}
|