Files
Ergo/src/pages/Admin/Faq/AddAdminFaqPage.jsx
T
2025-01-24 20:05:48 +01:00

177 lines
4.9 KiB
React

import React from "react";
import { useForm } from "react-hook-form";
import { yupResolver } from "@hookform/resolvers/yup";
import * as yup from "yup";
import MkdSDK from "@/utils/MkdSDK";
import { useNavigate } from "react-router-dom";
import { tokenExpireError, AuthContext } from "@/authContext";
import { GlobalContext, showToast } from "@/globalContext";
import AddAdminPageLayout from "@/layouts/AddAdminPageLayout";
import SunEditor, { buttonList } from "suneditor-react";
import "suneditor/dist/css/suneditor.min.css";
import { useState } from "react";
const AddAdminFaqPage = () => {
const { dispatch: globalDispatch } = React.useContext(GlobalContext);
const [answer, setAnswer] = useState("");
const schema = yup
.object({
question: yup.string().required("Question is required"),
answer: yup.string(),
status: yup.number(),
})
.required();
const { dispatch } = React.useContext(AuthContext);
const navigate = useNavigate();
const {
register,
handleSubmit,
setError,
formState: { errors },
} = useForm({
resolver: yupResolver(schema),
});
const onSubmit = async (data) => {
if (answer == "") {
setError("answer", {
type: "manual",
message: "Answer is required",
});
return;
}
let sdk = new MkdSDK();
try {
sdk.setTable("faq");
const result = await sdk.callRestAPI(
{
question: data.question,
answer,
status: data.status,
},
"POST",
);
if (!result.error) {
showToast(globalDispatch, "Added");
navigate("/admin/faq");
} else {
if (result.validation) {
const keys = Object.keys(result.validation);
for (let i = 0; i < keys.length; i++) {
const field = keys[i];
setError(field, {
type: "manual",
message: result.validation[field],
});
}
}
}
} catch (error) {
console.log("Error", error);
setError("question", {
type: "manual",
message: error.message,
});
tokenExpireError(dispatch, error.message);
}
};
const onError = () => {
setError("answer", {
type: "manual",
message: "Answer is required",
});
};
React.useEffect(() => {
globalDispatch({
type: "SETPATH",
payload: {
path: "faq",
},
});
}, []);
return (
<AddAdminPageLayout
title={"FAQ"}
backTo={"faq"}
>
<form
className=" w-full max-w-lg"
onSubmit={handleSubmit(onSubmit, onError)}
>
<div className="mb-4 ">
<label
className="block text-gray-700 text-sm font-bold mb-2"
htmlFor="question"
>
Question
</label>
<textarea
placeholder="Question"
{...register("question")}
className={`"shadow border rounded w-full py-2 px-3 text-gray-700 mb-3 leading-tight focus:outline-none focus:shadow-outline ${errors.question?.message ? "border-red-500" : ""}`}
rows={15}
></textarea>
<p className="text-red-500 text-xs italic normal-case">{errors.question?.message}</p>
</div>
<div className="mb-4 ">
<label
className="block text-gray-700 text-sm font-bold mb-2"
htmlFor="status"
>
Status
</label>
<select
className="border rounded w-full py-2 px-3 text-gray-700 mb-3 leading-tight focus:outline-none"
{...register("status")}
>
<option value="0">For customer</option>
<option value="1">For hosts</option>
</select>
</div>
<div className="mb-4 ">
<label
className="block text-gray-700 text-sm font-bold mb-2"
htmlFor="answer"
>
Answer
</label>
<SunEditor
width="100%"
height="400px"
onChange={(content) => setAnswer(content)}
placeholder="Add your answer here"
setOptions={{ buttonList: buttonList.complex }}
/>
<p className="text-red-500 text-xs italic normal-case">{errors.answer?.message}</p>
</div>
<div className="flex justify-between">
<button
onClick={() => navigate("/admin/faq")}
className="!bg-gradient-to-r flex-1 text-[#667085] font-semibold border border-[#667085] px-6 py-2 text-sm outline-none focus:outline-none mb-1 rounded"
>
Cancel
</button>
<button
type="submit"
className="!bg-gradient-to-r flex-1 from-[#33D4B7] to-[#0D9895] font-semibold text-white px-6 py-2 text-sm outline-none focus:outline-none ml-5 mb-1 rounded"
>
Save
</button>
</div>
</form>
</AddAdminPageLayout>
);
};
export default AddAdminFaqPage;