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

50 lines
1.6 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";
import { TFunction } from "i18next";
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,
setMember: (newMember: Member) => null | undefined,
t: TFunction<"translation", 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(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,
canCreate: false,
canUpdate: false,
canDelete: false,
2023-10-28 00:42:31 -05:00
userId: user.id,
2023-05-26 23:11:29 -05:00
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,
image: user.image,
2023-05-26 23:11:29 -05:00
},
});
}
} else if (checkIfMemberAlreadyExists) toast.error(t("user_already_member"));
2023-07-13 17:19:49 -05:00
else if (memberUsername.trim().toLowerCase() === ownerUsername.toLowerCase())
toast.error(t("you_are_already_collection_owner"));
};
export default addMemberToCollection;