From 461120ad8407bb679347bf448f7c49236418b166 Mon Sep 17 00:00:00 2001 From: Chiranjeev Vishnoi <66114276+Chiranjeev-droid@users.noreply.github.com> Date: Mon, 16 Oct 2023 15:09:05 +0530 Subject: [PATCH] fix: [CAL-2593] Uploading a CSV File does not comma separate the values (#11756) * csv email validation added * most common csv delimeters added --- .../components/MemberInvitationModal.tsx | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/packages/features/ee/teams/components/MemberInvitationModal.tsx b/packages/features/ee/teams/components/MemberInvitationModal.tsx index 020a4a7302cb10..72d2ce510832d3 100644 --- a/packages/features/ee/teams/components/MemberInvitationModal.tsx +++ b/packages/features/ee/teams/components/MemberInvitationModal.tsx @@ -143,11 +143,24 @@ export default function MemberInvitationModal(props: MemberInvitationModalProps) if (file) { const reader = new FileReader(); - + const emailRegex = /^([A-Z0-9_+-]+\.?)*[A-Z0-9_+-]@([A-Z0-9][A-Z0-9-]*\.)+[A-Z]{2,}$/i; reader.onload = (e) => { const contents = e?.target?.result as string; - const values = contents?.split(",").map((email) => email.trim().toLocaleLowerCase()); - newMemberFormMethods.setValue("emailOrUsername", values); + const lines = contents.split("\n"); + const validEmails = []; + for (const line of lines) { + const columns = line.split(/,|;|\|| /); + for (const column of columns) { + const email = column.trim().toLowerCase(); + + if (emailRegex.test(email)) { + validEmails.push(email); + break; // Stop checking columns if a valid email is found in this line + } + } + } + + newMemberFormMethods.setValue("emailOrUsername", validEmails); }; reader.readAsText(file);