You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
93 lines
2.9 KiB
93 lines
2.9 KiB
import { useEffect } from "react";
|
|
import { Controller, useForm } from "react-hook-form";
|
|
import { yupResolver } from "@hookform/resolvers/yup";
|
|
import * as yup from "yup";
|
|
|
|
import { useNotificationContext } from "@app/components/context/Notifications/NotificationProvider";
|
|
import { OrgPermissionCan } from "@app/components/permissions";
|
|
import { Button, FormControl, Input } from "@app/components/v2";
|
|
import { GeneralPermissionActions, OrgPermissionSubjects, useOrganization } from "@app/context";
|
|
import { withPermission } from "@app/hoc";
|
|
import { useRenameOrg } from "@app/hooks/api";
|
|
|
|
const formSchema = yup.object({
|
|
name: yup.string().required().label("Project Name")
|
|
});
|
|
|
|
type FormData = yup.InferType<typeof formSchema>;
|
|
|
|
export const OrgNameChangeSection = withPermission(
|
|
(): JSX.Element => {
|
|
const { currentOrg } = useOrganization();
|
|
const { createNotification } = useNotificationContext();
|
|
const { handleSubmit, control, reset } = useForm<FormData>({
|
|
resolver: yupResolver(formSchema)
|
|
});
|
|
const { mutateAsync, isLoading } = useRenameOrg();
|
|
|
|
useEffect(() => {
|
|
if (currentOrg) {
|
|
reset({ name: currentOrg.name });
|
|
}
|
|
}, [currentOrg]);
|
|
|
|
const onFormSubmit = async ({ name }: FormData) => {
|
|
try {
|
|
if (!currentOrg?._id) return;
|
|
if (name === "") return;
|
|
|
|
await mutateAsync({ orgId: currentOrg?._id, newOrgName: name });
|
|
createNotification({
|
|
text: "Successfully renamed organization",
|
|
type: "success"
|
|
});
|
|
} catch (error) {
|
|
console.error(error);
|
|
createNotification({
|
|
text: "Failed to rename organization",
|
|
type: "error"
|
|
});
|
|
}
|
|
};
|
|
|
|
return (
|
|
<form
|
|
onSubmit={handleSubmit(onFormSubmit)}
|
|
className="p-4 bg-mineshaft-900 mb-6 rounded-lg border border-mineshaft-600"
|
|
>
|
|
<p className="text-xl font-semibold text-mineshaft-100 mb-4">Organization name</p>
|
|
<div className="mb-2 max-w-md">
|
|
<Controller
|
|
defaultValue=""
|
|
render={({ field, fieldState: { error } }) => (
|
|
<FormControl isError={Boolean(error)} errorText={error?.message}>
|
|
<Input placeholder="Acme Corp" {...field} />
|
|
</FormControl>
|
|
)}
|
|
control={control}
|
|
name="name"
|
|
/>
|
|
</div>
|
|
<OrgPermissionCan I={GeneralPermissionActions.Edit} a={OrgPermissionSubjects.Settings}>
|
|
{(isAllowed) => (
|
|
<Button
|
|
isLoading={isLoading}
|
|
isDisabled={!isAllowed}
|
|
colorSchema="primary"
|
|
variant="outline_bg"
|
|
type="submit"
|
|
>
|
|
Save
|
|
</Button>
|
|
)}
|
|
</OrgPermissionCan>
|
|
</form>
|
|
);
|
|
},
|
|
{
|
|
action: GeneralPermissionActions.Read,
|
|
subject: OrgPermissionSubjects.Settings,
|
|
containerClassName: "mb-4"
|
|
}
|
|
);
|