"use client"; import type { FC } from "react"; import { useState } from "react"; import { isEmpty } from "lodash-es"; import Link from "next/link"; import { useForm } from "react-hook-form"; // plane internal packages import { API_BASE_URL } from "@plane/constants"; import { TOAST_TYPE, setToast } from "@plane/propel/toast"; import type { IFormattedInstanceConfiguration, TInstanceGiteaAuthenticationConfigurationKeys } from "@plane/types"; import { Button, getButtonStyling } from "@plane/ui"; import { cn } from "@plane/utils"; // components import { CodeBlock } from "@/components/common/code-block"; import { ConfirmDiscardModal } from "@/components/common/confirm-discard-modal"; import type { TControllerInputFormField } from "@/components/common/controller-input"; import { ControllerInput } from "@/components/common/controller-input"; import type { TCopyField } from "@/components/common/copy-field"; import { CopyField } from "@/components/common/copy-field"; // hooks import { useInstance } from "@/hooks/store"; type Props = { config: IFormattedInstanceConfiguration; }; type GiteaConfigFormValues = Record; export const InstanceGiteaConfigForm: FC = (props) => { const { config } = props; // states const [isDiscardChangesModalOpen, setIsDiscardChangesModalOpen] = useState(false); // store hooks const { updateInstanceConfigurations } = useInstance(); // form data const { handleSubmit, control, reset, formState: { errors, isDirty, isSubmitting }, } = useForm({ defaultValues: { GITEA_HOST: config["GITEA_HOST"] || "https://gitea.com", GITEA_CLIENT_ID: config["GITEA_CLIENT_ID"], GITEA_CLIENT_SECRET: config["GITEA_CLIENT_SECRET"], }, }); const originURL = !isEmpty(API_BASE_URL) ? API_BASE_URL : typeof window !== "undefined" ? window.location.origin : ""; const GITEA_FORM_FIELDS: TControllerInputFormField[] = [ { key: "GITEA_HOST", type: "text", label: "Gitea Host", description: ( <>Use the URL of your Gitea instance. For the official Gitea instance, use "https://gitea.com". ), placeholder: "https://gitea.com", error: Boolean(errors.GITEA_HOST), required: true, }, { key: "GITEA_CLIENT_ID", type: "text", label: "Client ID", description: ( <> You will get this from your{" "} Gitea OAuth application settings. ), placeholder: "70a44354520df8bd9bcd", error: Boolean(errors.GITEA_CLIENT_ID), required: true, }, { key: "GITEA_CLIENT_SECRET", type: "password", label: "Client secret", description: ( <> Your client secret is also found in your{" "} Gitea OAuth application settings. ), placeholder: "9b0050f94ec1b744e32ce79ea4ffacd40d4119cb", error: Boolean(errors.GITEA_CLIENT_SECRET), required: true, }, ]; const GITEA_SERVICE_FIELD: TCopyField[] = [ { key: "Callback_URI", label: "Callback URI", url: `${originURL}/auth/gitea/callback/`, description: ( <> We will auto-generate this. Paste this into your Authorized Callback URI{" "} field{" "} here. ), }, ]; const onSubmit = async (formData: GiteaConfigFormValues) => { const payload: Partial = { ...formData }; await updateInstanceConfigurations(payload) .then((response = []) => { setToast({ type: TOAST_TYPE.SUCCESS, title: "Done!", message: "Your Gitea authentication is configured. You should test it now.", }); reset({ GITEA_HOST: response.find((item) => item.key === "GITEA_HOST")?.value, GITEA_CLIENT_ID: response.find((item) => item.key === "GITEA_CLIENT_ID")?.value, GITEA_CLIENT_SECRET: response.find((item) => item.key === "GITEA_CLIENT_SECRET")?.value, }); }) .catch((err) => console.error(err)); }; const handleGoBack = (e: React.MouseEvent) => { if (isDirty) { e.preventDefault(); setIsDiscardChangesModalOpen(true); } }; return ( <> setIsDiscardChangesModalOpen(false)} />
Gitea-provided details for Plane
{GITEA_FORM_FIELDS.map((field) => ( ))}
Go back
Plane-provided details for Gitea
{GITEA_SERVICE_FIELD.map((field) => ( ))}
); };