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

49 lines
1.5 KiB
TypeScript
Raw Normal View History

2023-06-16 07:55:21 -05:00
import { CollectionIncludingMembersAndLinkCount, Member } from "@/types/global";
import getPublicUserData from "./getPublicUserData";
import { toast } from "react-hot-toast";
const addMemberToCollection = async (
2023-07-08 05:35:43 -05:00
ownerUsername: string,
memberUsername: 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-19 16:57:12 -05:00
const username = (e.user.username || "").toLowerCase();
2023-07-08 05:35:43 -05:00
return username === memberUsername.toLowerCase();
});
if (
// no duplicate members
!checkIfMemberAlreadyExists &&
// member can't be empty
2023-07-08 05:35:43 -05:00
memberUsername.trim() !== "" &&
// member can't be the owner
2023-07-13 17:19:49 -05:00
memberUsername.trim().toLowerCase() !== ownerUsername.toLowerCase()
) {
// Lookup, get data/err, list ...
const user = await getPublicUserData({
username: memberUsername.trim().toLowerCase(),
});
2023-07-08 05:35:43 -05:00
if (user.username) {
2023-05-26 23:11:29 -05:00
setMember({
collectionId: collection.id,
userId: user.id,
canCreate: false,
canUpdate: false,
canDelete: false,
user: {
2023-07-22 00:20:45 -05:00
id: user.id,
2023-05-26 23:11:29 -05:00
name: user.name,
2023-07-08 05:35:43 -05:00
username: user.username,
2023-05-26 23:11:29 -05:00
},
});
}
} else if (checkIfMemberAlreadyExists) toast.error("User already exists.");
2023-07-13 17:19:49 -05:00
else if (memberUsername.trim().toLowerCase() === ownerUsername.toLowerCase())
toast.error("You are already the collection owner.");
};
export default addMemberToCollection;