"use client"; import { useCallback, useEffect, useState } from "react"; import DOMPurify from "dompurify"; import { Controller, useForm } from "react-hook-form"; import * as z from "zod"; import { zodResolver } from "@hookform/resolvers/zod"; import { close, error, loading } from "@/config/swal"; import Swal from "sweetalert2"; import withReactContent from "sweetalert2-react-content"; import { useParams, useRouter } from "next/navigation"; import dynamic from "next/dynamic"; import { editCustomStaticPage, getCustomStaticDetail } from "@/service/static-page-service"; import { Card } from "@/components/ui/card"; import { Label } from "@/components/ui/label"; import { Input } from "@/components/ui/input"; import { Textarea } from "@/components/ui/textarea"; import { Button } from "@/components/ui/button"; const CustomEditor = dynamic( () => { return import("@/components/editor/custom-editor"); }, { ssr: false } ); const formSchema = z.object({ slug: z.string().min(2, { message: "Slug must be at least 2 characters.", }), title: z.string().min(2, { message: "Title must be at least 2 characters.", }), description: z.string().min(2, { message: "Main Keyword must be at least 2 characters.", }), htmlBody: z.string().min(2, { message: "Main Keyword must be at least 2 characters.", }), }); export default function StaticPageBuilderEdit() { const MySwal = withReactContent(Swal); const router = useRouter(); const params = useParams(); const id = params.id; const formOptions = { resolver: zodResolver(formSchema), }; type UserSettingSchema = z.infer; const { control, handleSubmit, formState: { errors }, watch, setValue, getValues, } = useForm(formOptions); useEffect(() => { initFetch(); }, [id]); const initFetch = async () => { const res = await getCustomStaticDetail(id ? String(id) : ""); const data = res?.data?.data; console.log("res", data); setValue("title", data?.title); setValue("slug", data?.slug); setValue("description", data?.description); setValue("htmlBody", addPreCode(data?.htmlBody)); }; const addPreCode = (htmlString: string): string => { const parser = new DOMParser(); const doc = parser.parseFromString(htmlString, "text/html"); const bodyContent = doc.body.innerHTML.trim(); return `
${bodyContent.replace(//g, ">")}
`; }; const content = watch("htmlBody"); const generatedPage = useCallback(() => { const sanitizedContent = DOMPurify.sanitize(content); const textArea = document.createElement("textarea"); textArea.innerHTML = sanitizedContent; return (
); }, [content]); function createSlug(value: string): string { return value .toLowerCase() .trim() .replace(/[^a-z0-9\s-]/g, "") .replace(/\s+/g, "-") .replace(/-+/g, "-"); } const onSubmit = async (values: z.infer) => { const request = { id: Number(id), title: values.title, slug: values.slug, description: values.description, htmlBody: values.htmlBody, }; loading(); const res = await editCustomStaticPage(request); if (res?.error) { error(res.message); return false; } close(); successSubmit("/admin/static-page"); }; function successSubmit(redirect: any) { MySwal.fire({ title: "Sukses", icon: "success", confirmButtonColor: "#3085d6", confirmButtonText: "OK", }).then((result) => { if (result.isConfirmed) { router.push(redirect); } }); } // const title = watch("title"); // useEffect(() => { // if (getValues("title")) { // setValue("slug", createSlug(getValues("title"))); // } // }, [title]); return (
(
)} /> {errors.title?.message &&

{errors.title?.message}

} (
)} />