forked from github/plane
127 lines
3.8 KiB
TypeScript
127 lines
3.8 KiB
TypeScript
|
import { FC } from "react";
|
||
|
import { Controller, useForm } from "react-hook-form";
|
||
|
// ui
|
||
|
import { Button, Input, ToggleSwitch } from "@plane/ui";
|
||
|
// types
|
||
|
import { IInstance } from "types/instance";
|
||
|
// hooks
|
||
|
import useToast from "hooks/use-toast";
|
||
|
import { useMobxStore } from "lib/mobx/store-provider";
|
||
|
|
||
|
export interface IInstanceGeneralForm {
|
||
|
instance: IInstance;
|
||
|
}
|
||
|
|
||
|
export interface GeneralFormValues {
|
||
|
instance_name: string;
|
||
|
is_telemetry_enabled: boolean;
|
||
|
}
|
||
|
|
||
|
export const InstanceGeneralForm: FC<IInstanceGeneralForm> = (props) => {
|
||
|
const { instance } = props;
|
||
|
// store
|
||
|
const { instance: instanceStore } = useMobxStore();
|
||
|
// toast
|
||
|
const { setToastAlert } = useToast();
|
||
|
// form data
|
||
|
const {
|
||
|
handleSubmit,
|
||
|
control,
|
||
|
formState: { errors, isSubmitting },
|
||
|
} = useForm<GeneralFormValues>({
|
||
|
defaultValues: {
|
||
|
instance_name: instance.instance_name,
|
||
|
is_telemetry_enabled: instance.is_telemetry_enabled,
|
||
|
},
|
||
|
});
|
||
|
|
||
|
const onSubmit = async (formData: GeneralFormValues) => {
|
||
|
const payload: Partial<GeneralFormValues> = { ...formData };
|
||
|
|
||
|
await instanceStore
|
||
|
.updateInstanceInfo(payload)
|
||
|
.then(() =>
|
||
|
setToastAlert({
|
||
|
title: "Success",
|
||
|
type: "success",
|
||
|
message: "Settings updated successfully",
|
||
|
})
|
||
|
)
|
||
|
.catch((err) => console.error(err));
|
||
|
};
|
||
|
|
||
|
return (
|
||
|
<div className="flex flex-col gap-8 m-8">
|
||
|
<div className="grid grid-col grid-cols-1 lg:grid-cols-2 2xl:grid-cols-3 items-center justify-between gap-8 w-full">
|
||
|
<div className="flex flex-col gap-1">
|
||
|
<h4 className="text-sm">Name of instance</h4>
|
||
|
<Controller
|
||
|
control={control}
|
||
|
name="instance_name"
|
||
|
render={({ field: { value, onChange, ref } }) => (
|
||
|
<Input
|
||
|
id="instance_name"
|
||
|
name="instance_name"
|
||
|
type="text"
|
||
|
value={value}
|
||
|
onChange={onChange}
|
||
|
ref={ref}
|
||
|
hasError={Boolean(errors.instance_name)}
|
||
|
placeholder="Instance Name"
|
||
|
className="rounded-md font-medium w-full"
|
||
|
/>
|
||
|
)}
|
||
|
/>
|
||
|
</div>
|
||
|
|
||
|
<div className="flex flex-col gap-1">
|
||
|
<h4 className="text-sm">Admin Email</h4>
|
||
|
<Input
|
||
|
id="primary_email"
|
||
|
name="primary_email"
|
||
|
type="email"
|
||
|
value={instance.primary_email}
|
||
|
placeholder="Admin Email"
|
||
|
className="w-full cursor-not-allowed !text-custom-text-400"
|
||
|
disabled
|
||
|
/>
|
||
|
</div>
|
||
|
|
||
|
<div className="flex flex-col gap-1">
|
||
|
<h4 className="text-sm">Instance Id</h4>
|
||
|
<Input
|
||
|
id="instance_id"
|
||
|
name="instance_id"
|
||
|
type="text"
|
||
|
value={instance.instance_id}
|
||
|
className="rounded-md font-medium w-full cursor-not-allowed !text-custom-text-400"
|
||
|
disabled
|
||
|
/>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
<div className="flex items-center gap-8 pt-4">
|
||
|
<div>
|
||
|
<div className="text-custom-text-100 font-medium text-sm">Share anonymous usage instance</div>
|
||
|
<div className="text-custom-text-300 font-normal text-xs">
|
||
|
Help us understand how you use Plane so we can build better for you.
|
||
|
</div>
|
||
|
</div>
|
||
|
<div>
|
||
|
<Controller
|
||
|
control={control}
|
||
|
name="is_telemetry_enabled"
|
||
|
render={({ field: { value, onChange } }) => <ToggleSwitch value={value} onChange={onChange} size="sm" />}
|
||
|
/>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
<div className="flex items-center py-1">
|
||
|
<Button variant="primary" onClick={handleSubmit(onSubmit)} loading={isSubmitting}>
|
||
|
{isSubmitting ? "Saving..." : "Save Changes"}
|
||
|
</Button>
|
||
|
</div>
|
||
|
</div>
|
||
|
);
|
||
|
};
|