forked from github/plane
d3b73dc32f
* feat: manual ordering for issues in kanban * refactor: issues folder structure * refactor: modules and states folder structure * refactor: datepicker code * fix: create issue modal bug * feat: custom progress bar added * refactor: created global component for kanban board * refactor: update cycle and module issue create * refactor: return modules created * refactor: integrated global kanban view everywhere * refactor: integrated global list view everywhere * refactor: removed unnecessary api calls * refactor: update nomenclature for consistency * refactor: global select component for issue view * refactor: track cycles and modules for issue * fix: tracking new cycles and modules in activities * feat: segregate api token workspace * fix: workpsace id during token creation * refactor: update model association to cascade on delete * feat: sentry integrated (#235) * feat: sentry integrated * fix: removed unnecessary env variable * fix: update remirror description to save empty string and empty paragraph (#237) * Update README.md * fix: description and comment_json default value to remove warnings * feat: link option in remirror (#240) * feat: link option in remirror * fix: removed link import from remirror toolbar * feat: module and cycle settings under project * fix: module issue assignment * fix: module issue updation and activity logging * fix: typo while creating module issues * fix: string comparison for update operation * fix: ui fixes (#246) * style: shortcut command label bg color change * sidebar shortcut ui fix --------- Co-authored-by: Anmol Singh Bhatia <anmolsinghbhatia1001@gmail.com> * fix: update empty passwords to hashed string and add hashing for magic sign in * refactor: remove print logs from back migrations * build(deps): bump django in /apiserver/requirements Bumps [django](https://github.com/django/django) from 3.2.16 to 3.2.17. - [Release notes](https://github.com/django/django/releases) - [Commits](https://github.com/django/django/compare/3.2.16...3.2.17) --- updated-dependencies: - dependency-name: django dependency-type: direct:production ... Signed-off-by: dependabot[bot] <support@github.com> * feat: cycles and modules toggle in settings, refactor: folder structure (#247) * feat: link option in remirror * fix: removed link import from remirror toolbar * refactor: constants folder * refactor: layouts folder structure * fix: issue view context * feat: cycles and modules toggle in settings --------- Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: pablohashescobar <nikhilschacko@gmail.com> Co-authored-by: Aaryan Khandelwal <aaryankhandu123@gmail.com> Co-authored-by: Anmol Singh Bhatia <anmolsinghbhatia1001@gmail.com> Co-authored-by: Aaryan Khandelwal <65252264+aaryan610@users.noreply.github.com> Co-authored-by: pablohashescobar <118773738+pablohashescobar@users.noreply.github.com> Co-authored-by: sphynxux <122926002+sphynxux@users.noreply.github.com> Co-authored-by: Anmol Singh Bhatia <121005188+anmolsinghbhatia@users.noreply.github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
135 lines
3.6 KiB
TypeScript
135 lines
3.6 KiB
TypeScript
import React, { useState } from "react";
|
|
import { useForm } from "react-hook-form";
|
|
// ui
|
|
import { CheckCircleIcon } from "@heroicons/react/20/solid";
|
|
import { Button, Input } from "components/ui";
|
|
// services
|
|
import authenticationService from "services/authentication.service";
|
|
import useToast from "hooks/use-toast";
|
|
// icons
|
|
|
|
// types
|
|
type EmailCodeFormValues = {
|
|
email: string;
|
|
key?: string;
|
|
token?: string;
|
|
};
|
|
|
|
export const EmailCodeForm = ({ onSuccess }: any) => {
|
|
const [codeSent, setCodeSent] = useState(false);
|
|
const { setToastAlert } = useToast();
|
|
const {
|
|
register,
|
|
handleSubmit,
|
|
setError,
|
|
setValue,
|
|
formState: { errors, isSubmitting, isValid, isDirty },
|
|
} = useForm<EmailCodeFormValues>({
|
|
defaultValues: {
|
|
email: "",
|
|
key: "",
|
|
token: "",
|
|
},
|
|
mode: "onChange",
|
|
reValidateMode: "onChange",
|
|
});
|
|
|
|
const onSubmit = ({ email }: EmailCodeFormValues) => {
|
|
authenticationService
|
|
.emailCode({ email })
|
|
.then((res) => {
|
|
setValue("key", res.key);
|
|
setCodeSent(true);
|
|
})
|
|
.catch((err) => {
|
|
console.log(err);
|
|
});
|
|
};
|
|
|
|
const handleSignin = (formData: EmailCodeFormValues) => {
|
|
authenticationService
|
|
.magicSignIn(formData)
|
|
.then((response) => {
|
|
onSuccess(response);
|
|
})
|
|
.catch((error) => {
|
|
console.log(error);
|
|
setToastAlert({
|
|
title: "Oops!",
|
|
type: "error",
|
|
message: "Enter the correct code to sign in",
|
|
});
|
|
setError("token" as keyof EmailCodeFormValues, {
|
|
type: "manual",
|
|
message: error.error,
|
|
});
|
|
});
|
|
};
|
|
|
|
return (
|
|
<>
|
|
<form
|
|
className="mt-5 space-y-5"
|
|
onSubmit={codeSent ? handleSubmit(handleSignin) : handleSubmit(onSubmit)}
|
|
>
|
|
{codeSent && (
|
|
<div className="rounded-md bg-green-50 p-4">
|
|
<div className="flex">
|
|
<div className="flex-shrink-0">
|
|
<CheckCircleIcon className="h-5 w-5 text-green-400" aria-hidden="true" />
|
|
</div>
|
|
<div className="ml-3">
|
|
<p className="text-sm font-medium text-green-800">
|
|
Please check your mail for code.
|
|
</p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
)}
|
|
<div>
|
|
<Input
|
|
id="email"
|
|
type="email"
|
|
name="email"
|
|
register={register}
|
|
validations={{
|
|
required: "Email ID is required",
|
|
validate: (value) =>
|
|
/^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|(\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/.test(
|
|
value
|
|
) || "Email ID is not valid",
|
|
}}
|
|
error={errors.email}
|
|
placeholder="Enter your Email ID"
|
|
/>
|
|
</div>
|
|
|
|
{codeSent && (
|
|
<div>
|
|
<Input
|
|
id="token"
|
|
type="token"
|
|
name="token"
|
|
register={register}
|
|
validations={{
|
|
required: "Code is required",
|
|
}}
|
|
error={errors.token}
|
|
placeholder="Enter code"
|
|
/>
|
|
</div>
|
|
)}
|
|
<div>
|
|
<Button
|
|
disabled={isSubmitting || (!isValid && isDirty)}
|
|
className="w-full text-center"
|
|
type="submit"
|
|
>
|
|
{isSubmitting ? "Signing in..." : codeSent ? "Sign In" : "Continue with Email ID"}
|
|
</Button>
|
|
</div>
|
|
</form>
|
|
</>
|
|
);
|
|
};
|