el.xwx.moe/lib/client/addMemberToCollection.ts

48 lines
1.4 KiB
TypeScript
Raw Normal View History

2023-06-16 07:55:21 -05:00
import { CollectionIncludingMembersAndLinkCount, Member } from "@/types/global";
import getPublicUserDataByEmail from "./getPublicUserDataByEmail";
import { toast } from "react-hot-toast";
const addMemberToCollection = async (
ownerEmail: string,
memberEmail: string,
2023-06-16 07:55:21 -05:00
collection: CollectionIncludingMembersAndLinkCount,
2023-05-26 23:11:29 -05:00
setMember: (newMember: Member) => null | undefined
) => {
2023-05-26 23:11:29 -05:00
const checkIfMemberAlreadyExists = collection.members.find((e) => {
2023-07-03 15:43:53 -05:00
const email = e.user.email.toLowerCase();
return email === memberEmail.toLowerCase();
});
if (
// no duplicate members
!checkIfMemberAlreadyExists &&
// member can't be empty
memberEmail.trim() !== "" &&
// member can't be the owner
memberEmail.trim() !== ownerEmail
) {
// Lookup, get data/err, list ...
2023-07-03 15:43:53 -05:00
const user = await getPublicUserDataByEmail(
memberEmail.trim().toLowerCase()
);
2023-05-26 23:11:29 -05:00
if (user.email) {
setMember({
collectionId: collection.id,
userId: user.id,
canCreate: false,
canUpdate: false,
canDelete: false,
user: {
name: user.name,
email: user.email,
},
});
}
} else if (checkIfMemberAlreadyExists) toast.error("User already exists.");
else if (memberEmail.trim() === ownerEmail)
toast.error("You are already the collection owner.");
};
export default addMemberToCollection;