From 3f6efa99c35056b2ce0a5bd6bafa9f233c972fd2 Mon Sep 17 00:00:00 2001 From: shahanneda Date: Sat, 21 Jan 2023 15:50:36 -0500 Subject: [PATCH 1/2] Fixed exec name showing middle name --- lib/team.ts | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/lib/team.ts b/lib/team.ts index f1ad11e6..5670ae47 100644 --- a/lib/team.ts +++ b/lib/team.ts @@ -56,9 +56,11 @@ async function getExec(name: string, pos: string) { metadata: { ...metadata, image } as Metadata, }; } catch (err) { + const nameParts = name.split("-"); + // Capitalize the first letter of the first name and last name - const firstName = capitalize(name.split("-")[0]); - const lastName = capitalize(name.split("-")[1]); + const firstName = capitalize(nameParts[0]); + const lastName = capitalize(nameParts[nameParts.length - 1]); const posName = execPositions[pos]; content = "Coming Soon!"; -- 2.39.5 From 10f43b7eb31cc32bace6360b3ddc9fae611f5be2 Mon Sep 17 00:00:00 2001 From: shahanneda Date: Sat, 21 Jan 2023 16:59:27 -0500 Subject: [PATCH 2/2] Refactored code to use proper types --- lib/team.ts | 71 +++++++++++++++++++++++++++++++++-------------------- 1 file changed, 45 insertions(+), 26 deletions(-) diff --git a/lib/team.ts b/lib/team.ts index 5670ae47..06cef786 100644 --- a/lib/team.ts +++ b/lib/team.ts @@ -31,22 +31,32 @@ export interface Metadata { role?: string; image: string; } - -export async function getExecs() { - const execNamePosPairs = await getExecNamePosPairs(); - - return await Promise.all( - execNamePosPairs.map((namePosPair) => - getExec(namePosPair[0], namePosPair[1]) - ) - ); +interface Person { + firstName: string; + lastName: string; } -async function getExec(name: string, pos: string) { +interface Exec { + person: Person; + position: string; +} + +export async function getExecs() { + const execs = await getExecNamePosPairs(); + + return await Promise.all(execs.map(getExec)); +} + +async function getExec(exec: Exec) { let content, metadata; + const expectedFileName = + `${exec.person.firstName}` + + (exec.person.lastName ? `-${exec.person.lastName}` : ""); try { - const raw = await readFile(path.join(EXECS_PATH, `${name}${FILETYPE}`)); + const raw = await readFile( + path.join(EXECS_PATH, `${expectedFileName}${FILETYPE}`) + ); ({ content, data: metadata } = matter(raw)); const image = await getMemberImagePath(metadata.name as string); @@ -56,13 +66,11 @@ async function getExec(name: string, pos: string) { metadata: { ...metadata, image } as Metadata, }; } catch (err) { - const nameParts = name.split("-"); - // Capitalize the first letter of the first name and last name - const firstName = capitalize(nameParts[0]); - const lastName = capitalize(nameParts[nameParts.length - 1]); + const firstName = capitalize(exec.person.firstName); + const lastName = capitalize(exec.person.lastName); - const posName = execPositions[pos]; + const posName = execPositions[exec.position]; content = "Coming Soon!"; metadata = { name: `${firstName} ${lastName}`, @@ -78,11 +86,14 @@ async function getExec(name: string, pos: string) { } } -async function getExecNamePosPairs(): Promise< - [person: string, position: string][] -> { +async function getExecNamePosPairs(): Promise { + const CodeyExec = { + person: { firstName: "codey", lastName: "" }, + position: "mascot", + }; + if (process.env.USE_LDAP?.toLowerCase() !== "true") { - return [["codey", "mascot"]]; + return [CodeyExec]; } const url = "ldap://ldap1.csclub.uwaterloo.ca"; @@ -91,7 +102,8 @@ async function getExecNamePosPairs(): Promise< // position: name const execMembers: { [position: string]: string } = {}; - let formattedExec: [person: string, position: string][] = []; + + let formattedExec: Exec[] = []; try { await client.bind("", ""); @@ -139,13 +151,20 @@ async function getExecNamePosPairs(): Promise< if (fullName == undefined) { return null; } - const firstName = fullName.split(" ")[0].toLowerCase(); - const lastName = fullName.split(" ")[1].toLowerCase(); - return [`${firstName}-${lastName}`, position]; + const nameParts = fullName.split(" "); + const firstName = nameParts[0].toLowerCase(); + const lastName = + nameParts.length > 1 + ? nameParts[nameParts.length - 1].toLowerCase() + : ""; + return { + person: { firstName: firstName, lastName: lastName }, + position: position, + }; }) - .filter((pair) => pair != null) as [person: string, position: string][]; + .filter((pair) => pair != null) as Exec[]; - formattedExec = [...formattedExec, ["codey", "mascot"]]; + formattedExec = [...formattedExec, CodeyExec]; } finally { await client.unbind(); } -- 2.39.5