2021-07-31 17:22:48 +00:00
|
|
|
import type { BlitzPage, GetServerSideProps } from "blitz";
|
|
|
|
import { getSession, Routes, useMutation, useRouter } from "blitz";
|
2021-07-31 15:57:43 +00:00
|
|
|
import clsx from "clsx";
|
|
|
|
import { useEffect } from "react";
|
|
|
|
import { useForm } from "react-hook-form";
|
2021-07-18 15:32:45 +00:00
|
|
|
|
2021-07-31 17:22:48 +00:00
|
|
|
import db from "db";
|
|
|
|
import setTwilioApiFields from "../../mutations/set-twilio-api-fields";
|
2021-07-31 15:57:43 +00:00
|
|
|
import OnboardingLayout from "../../components/onboarding-layout";
|
|
|
|
import useCurrentCustomer from "../../../core/hooks/use-current-customer";
|
2021-07-18 15:32:45 +00:00
|
|
|
|
|
|
|
type Form = {
|
2021-07-31 15:57:43 +00:00
|
|
|
twilioAccountSid: string;
|
|
|
|
twilioAuthToken: string;
|
|
|
|
};
|
2021-07-18 15:32:45 +00:00
|
|
|
|
2021-07-31 14:33:18 +00:00
|
|
|
const StepTwo: BlitzPage = () => {
|
2021-07-18 15:32:45 +00:00
|
|
|
const {
|
|
|
|
register,
|
|
|
|
handleSubmit,
|
|
|
|
setValue,
|
|
|
|
formState: { isSubmitting },
|
2021-07-31 15:57:43 +00:00
|
|
|
} = useForm<Form>();
|
|
|
|
const router = useRouter();
|
|
|
|
const { customer } = useCurrentCustomer();
|
|
|
|
const [setTwilioApiFieldsMutation] = useMutation(setTwilioApiFields);
|
2021-07-18 15:32:45 +00:00
|
|
|
|
|
|
|
useEffect(() => {
|
2021-08-01 03:05:40 +00:00
|
|
|
setValue("twilioAuthToken", customer?.authToken ?? "");
|
|
|
|
setValue("twilioAccountSid", customer?.accountSid ?? "");
|
|
|
|
}, [setValue, customer?.authToken, customer?.accountSid]);
|
2021-07-18 15:32:45 +00:00
|
|
|
|
|
|
|
const onSubmit = handleSubmit(async ({ twilioAccountSid, twilioAuthToken }) => {
|
|
|
|
if (isSubmitting) {
|
2021-07-31 15:57:43 +00:00
|
|
|
return;
|
2021-07-18 15:32:45 +00:00
|
|
|
}
|
|
|
|
|
2021-07-31 14:33:18 +00:00
|
|
|
await setTwilioApiFieldsMutation({
|
2021-07-18 15:32:45 +00:00
|
|
|
twilioAccountSid,
|
|
|
|
twilioAuthToken,
|
2021-07-31 15:57:43 +00:00
|
|
|
});
|
2021-07-31 14:33:18 +00:00
|
|
|
|
2021-07-31 15:57:43 +00:00
|
|
|
await router.push(Routes.StepThree());
|
|
|
|
});
|
2021-07-18 15:32:45 +00:00
|
|
|
|
2021-08-01 03:05:40 +00:00
|
|
|
return (
|
|
|
|
<div className="flex flex-col space-y-4 items-center">
|
|
|
|
<form onSubmit={onSubmit} className="flex flex-col gap-6">
|
|
|
|
<div className="w-full">
|
|
|
|
<label
|
|
|
|
htmlFor="twilioAccountSid"
|
|
|
|
className="block text-sm font-medium text-gray-700"
|
|
|
|
>
|
|
|
|
Twilio Account SID
|
|
|
|
</label>
|
|
|
|
<input
|
|
|
|
type="text"
|
|
|
|
id="twilioAccountSid"
|
|
|
|
className="mt-1 block w-full border border-gray-300 rounded-md shadow-sm py-2 px-3 focus:outline-none focus:ring-primary-500 focus:border-primary-500 sm:text-sm"
|
|
|
|
{...register("twilioAccountSid", { required: true })}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
<div className="w-full">
|
|
|
|
<label
|
|
|
|
htmlFor="twilioAuthToken"
|
|
|
|
className="block text-sm font-medium text-gray-700"
|
|
|
|
>
|
|
|
|
Twilio Auth Token
|
|
|
|
</label>
|
|
|
|
<input
|
|
|
|
type="text"
|
|
|
|
id="twilioAuthToken"
|
|
|
|
className="mt-1 block w-full border border-gray-300 rounded-md shadow-sm py-2 px-3 focus:outline-none focus:ring-primary-500 focus:border-primary-500 sm:text-sm"
|
|
|
|
{...register("twilioAuthToken", { required: true })}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<button
|
|
|
|
type="submit"
|
|
|
|
className={clsx(
|
|
|
|
"max-w-[240px] mx-auto w-full inline-flex justify-center rounded-md border border-transparent shadow-sm px-4 py-2 text-base font-medium text-white focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-primary-500 sm:text-sm",
|
|
|
|
!isSubmitting && "bg-primary-600 hover:bg-primary-700",
|
|
|
|
isSubmitting && "bg-primary-400 cursor-not-allowed"
|
|
|
|
)}
|
|
|
|
>
|
|
|
|
Save
|
|
|
|
</button>
|
|
|
|
</form>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
StepTwo.getLayout = function StepTwoLayout(page) {
|
|
|
|
const { customer } = useCurrentCustomer();
|
|
|
|
const initialAuthToken = customer?.authToken ?? "";
|
|
|
|
const initialAccountSid = customer?.accountSid ?? "";
|
|
|
|
const hasTwilioCredentials = initialAccountSid.length > 0 && initialAuthToken.length > 0;
|
|
|
|
|
2021-07-18 15:32:45 +00:00
|
|
|
return (
|
|
|
|
<OnboardingLayout
|
|
|
|
currentStep={2}
|
2021-08-01 03:05:40 +00:00
|
|
|
next={
|
|
|
|
hasTwilioCredentials
|
|
|
|
? { href: Routes.StepThree().pathname, label: "Next" }
|
|
|
|
: undefined
|
|
|
|
}
|
|
|
|
previous={{ href: Routes.StepOne().pathname, label: "Back" }}
|
2021-07-18 15:32:45 +00:00
|
|
|
>
|
2021-08-01 03:05:40 +00:00
|
|
|
{page}
|
2021-07-18 15:32:45 +00:00
|
|
|
</OnboardingLayout>
|
2021-07-31 15:57:43 +00:00
|
|
|
);
|
|
|
|
};
|
2021-07-18 15:32:45 +00:00
|
|
|
|
2021-08-01 03:05:40 +00:00
|
|
|
StepTwo.authenticate = { redirectTo: Routes.SignIn() };
|
2021-07-18 15:32:45 +00:00
|
|
|
|
2021-07-31 17:22:48 +00:00
|
|
|
export const getServerSideProps: GetServerSideProps = async ({ req, res }) => {
|
|
|
|
const session = await getSession(req, res);
|
|
|
|
if (!session.userId) {
|
|
|
|
await session.$revoke();
|
|
|
|
return {
|
|
|
|
redirect: {
|
|
|
|
destination: Routes.Home().pathname,
|
|
|
|
permanent: false,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
const phoneNumber = await db.phoneNumber.findFirst({ where: { customerId: session.userId } });
|
|
|
|
if (!phoneNumber) {
|
|
|
|
return { props: {} };
|
|
|
|
}
|
|
|
|
|
|
|
|
return {
|
|
|
|
redirect: {
|
|
|
|
destination: Routes.Messages().pathname,
|
|
|
|
permanent: false,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2021-07-31 15:57:43 +00:00
|
|
|
export default StepTwo;
|