PR feedback
continuous-integration/drone/push Build is passing Details

This commit is contained in:
Aditya Thakral 2021-08-27 16:04:03 -04:00
parent 95d3328cda
commit e1b41e2a37
2 changed files with 87 additions and 109 deletions

View File

@ -60,15 +60,13 @@ export async function getEventsByTerm(
year: string, year: string,
term: string term: string
): Promise<string[]> { ): Promise<string[]> {
let retval: string[] = [];
try { try {
retval = (await fs.readdir(path.join(EVENTS_PATH, year, term))) return (await fs.readdir(path.join(EVENTS_PATH, year, term)))
.filter((name) => name.endsWith(".md")) .filter((name) => name.endsWith(".md"))
.map((name) => name.slice(0, -".md".length)); .map((name) => name.slice(0, -".md".length));
} catch { } catch {
return []; return [];
} }
return retval;
} }
export async function getUpcomingEvents(): Promise<Event[]> { export async function getUpcomingEvents(): Promise<Event[]> {
@ -106,10 +104,7 @@ export async function getUpcomingEvents(): Promise<Event[]> {
}); });
} }
export async function getProps( export async function getProps(year: string, term: string): Promise<Props> {
year: string,
term: string
): Promise<{ props: Props }> {
const eventNames = await getEventsByTerm(year, term); const eventNames = await getEventsByTerm(year, term);
const events: Event[] = ( const events: Event[] = (
@ -145,6 +140,7 @@ export async function getProps(
pastTerms.push(pastTerm); pastTerms.push(pastTerm);
} }
} }
pastTerms.reverse();
const maxYear = eventYears[eventYears.length - 1]; const maxYear = eventYears[eventYears.length - 1];
const futureTerms: { year: string; term: string }[] = []; const futureTerms: { year: string; term: string }[] = [];
@ -163,15 +159,13 @@ export async function getProps(
} }
return { return {
props: { year: year,
year: year, term: term,
term: term, pastEvents: pastEvents,
pastEvents: pastEvents, futureEvents: futureEvents,
futureEvents: futureEvents, isCurrentTerm: term === current.term && year === current.year,
isCurrentTerm: term === current.term && year === current.year, pastTerms: pastTerms,
pastTerms: pastTerms, futureTerms: futureTerms,
futureTerms: futureTerms,
},
}; };
} }
@ -181,18 +175,18 @@ export function getCurrentTerm(): { year: string; term: string } {
const year = date.getUTCFullYear().toString(); const year = date.getUTCFullYear().toString();
if ( if (
new Date(`${year}-01-01`).getTime() <= date.getTime() && new Date(`${year}-01-01 EST`).getTime() <= date.getTime() &&
date.getTime() <= new Date(`${year}-04-30`).getTime() date.getTime() <= new Date(`${year}-04-30 EST`).getTime()
) { ) {
term = "winter"; term = "winter";
} else if ( } else if (
new Date(`${year}-05-01`).getTime() <= date.getTime() && new Date(`${year}-05-01 EST`).getTime() <= date.getTime() &&
date.getTime() <= new Date(`${year}-08-31`).getTime() date.getTime() <= new Date(`${year}-08-31 EST`).getTime()
) { ) {
term = "spring"; term = "spring";
} else if ( } else if (
new Date(`${year}-09-01`).getTime() <= date.getTime() && new Date(`${year}-09-01 EST`).getTime() <= date.getTime() &&
date.getTime() <= new Date(`${year}-12-31`).getTime() date.getTime() <= new Date(`${year}-12-31 EST`).getTime()
) { ) {
term = "fall"; term = "fall";
} }
@ -205,20 +199,20 @@ function getPastTerm(
term: string term: string
): { year: string; term: string } { ): { year: string; term: string } {
const index = TERMS.indexOf(term); const index = TERMS.indexOf(term);
if (index === -1) { if (index === -1) {
console.error("Not a valid term"); throw new Error("Not a valid term");
return { year: "", term: "" };
} else if (index === 0) {
return {
year: (parseInt(year) - 1).toString(),
term: TERMS[TERMS.length - 1],
};
} else {
return {
year: year,
term: TERMS[index - 1],
};
} }
return index === 0
? {
year: (parseInt(year) - 1).toString(),
term: TERMS[TERMS.length - 1],
}
: {
year: year,
term: TERMS[index - 1],
};
} }
function getFutureTerm( function getFutureTerm(
@ -226,18 +220,18 @@ function getFutureTerm(
term: string term: string
): { year: string; term: string } { ): { year: string; term: string } {
const index = TERMS.indexOf(term); const index = TERMS.indexOf(term);
if (index === -1) { if (index === -1) {
console.error("Not a valid term"); throw new Error("Not a valid term");
return { year: "", term: "" };
} else if (index === TERMS.length - 1) {
return {
year: (parseInt(year) + 1).toString(),
term: TERMS[0],
};
} else {
return {
year: year,
term: TERMS[index + 1],
};
} }
return index === TERMS.length - 1
? {
year: (parseInt(year) + 1).toString(),
term: TERMS[0],
}
: {
year: year,
term: TERMS[index + 1],
};
} }

View File

@ -27,72 +27,42 @@ export interface Props {
} }
export default function Term(props: Props) { export default function Term(props: Props) {
const hasPastTerms = props.pastTerms.length !== 0; let headerTerms = [{ year: props.year, term: props.term }];
const hasFutureTerms = props.futureTerms.length !== 0;
// p, Current, f
if (props.pastTerms.length > 0 && props.futureTerms.length > 0) {
headerTerms = [
...props.pastTerms.slice(-1),
...headerTerms,
...props.futureTerms.slice(0, 1),
];
}
// p, p, Current
else if (props.pastTerms.length > 0) {
headerTerms = [...props.pastTerms.slice(-2), ...headerTerms];
}
// Current, f, f
else {
headerTerms = [...headerTerms, ...props.futureTerms.slice(0, 2)];
}
headerTerms.reverse();
const hasPastEvents = props.pastEvents.length !== 0; const hasPastEvents = props.pastEvents.length !== 0;
const hasFutureEvents = props.futureEvents.length !== 0; const hasFutureEvents = props.futureEvents.length !== 0;
return ( return (
<div className={styles.main}> <div className={styles.main}>
{!hasPastTerms && hasFutureTerms && ( <div className={styles.header}>
<div className={styles.header}> {headerTerms.map((link) => (
<Link href={`/events/${props.year}/${props.term}`}> <HeaderLink
<span className={styles.curTerm}> {...link}
{`${capitalize(props.term)} ${props.year}`} isCurrentTerm={link.year === props.year && link.term === props.term}
</span> key={link.year + link.term}
</Link> />
<Link ))}
href={`/events/${props.futureTerms[0].year}/${props.futureTerms[0].term}`} <Link href="/events/archives">Archives</Link>
>{`${capitalize(props.futureTerms[0].term)} ${ </div>
props.futureTerms[0].year
}`}</Link>
<Link
href={`/events/${props.futureTerms[1].year}/${props.futureTerms[1].term}`}
>{`${capitalize(props.futureTerms[1].term)} ${
props.futureTerms[1].year
}`}</Link>
<Link href={"/events/archives"}>Archives</Link>
</div>
)}
{hasPastTerms && hasFutureTerms && (
<div className={styles.header}>
<Link
href={`/events/${props.pastTerms[0].year}/${props.pastTerms[0].term}`}
>{`${capitalize(props.pastTerms[0].term)} ${
props.pastTerms[0].year
}`}</Link>
<Link href={`/events/${props.year}/${props.term}`}>
<span className={styles.curTerm}>
{`${capitalize(props.term)} ${props.year}`}
</span>
</Link>
<Link
href={`/events/${props.futureTerms[0].year}/${props.futureTerms[0].term}`}
>{`${capitalize(props.futureTerms[0].term)} ${
props.futureTerms[0].year
}`}</Link>
<Link href={"/events/archives"}>Archives</Link>
</div>
)}
{hasPastTerms && !hasFutureTerms && (
<div className={styles.header}>
<Link
href={`/events/${props.pastTerms[1].year}/${props.pastTerms[1].term}`}
>{`${capitalize(props.pastTerms[1].term)} ${
props.pastTerms[1].year
} `}</Link>
<Link
href={`/events/${props.pastTerms[0].year}/${props.pastTerms[0].term}`}
>{`${capitalize(props.pastTerms[0].term)} ${
props.pastTerms[0].year
}`}</Link>
<Link href={`/events/${props.year}/${props.term}`}>
<span className={styles.curTerm}>
{`${capitalize(props.term)} ${props.year}`}
</span>
</Link>
<Link href={"/events/archives"}>Archives</Link>
</div>
)}
{hasFutureEvents && ( {hasFutureEvents && (
<> <>
<h2>Upcoming Events</h2> <h2>Upcoming Events</h2>
@ -132,6 +102,20 @@ export default function Term(props: Props) {
); );
} }
function HeaderLink(props: {
year: string;
term: string;
isCurrentTerm?: boolean;
}) {
return (
<Link href={`/events/${props.year}/${props.term}`}>
<span className={props.isCurrentTerm ? styles.curTerm : ""}>
{`${capitalize(props.term)} ${props.year}`}
</span>
</Link>
);
}
interface Params extends ParsedUrlQuery { interface Params extends ParsedUrlQuery {
year: string; year: string;
term: string; term: string;
@ -143,7 +127,7 @@ export const getStaticProps: GetStaticProps<Props, Params> = async (
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
const { year, term } = context.params!; const { year, term } = context.params!;
return await getProps(year, term); return { props: await getProps(year, term) };
}; };
export const getStaticPaths: GetStaticPaths<Params> = async () => { export const getStaticPaths: GetStaticPaths<Params> = async () => {