Skip to content

Commit

Permalink
Merge branch 'develop' into prefetch-dashboard
Browse files Browse the repository at this point in the history
  • Loading branch information
Jake3231 authored Oct 11, 2023
2 parents 399aa6b + 55313b0 commit bad55ce
Show file tree
Hide file tree
Showing 37 changed files with 11,672 additions and 28,709 deletions.
3 changes: 0 additions & 3 deletions .eslintrc.json

This file was deleted.

5 changes: 0 additions & 5 deletions apitesting.http

This file was deleted.

6 changes: 0 additions & 6 deletions commitlint.config.js

This file was deleted.

118 changes: 0 additions & 118 deletions components/autocomplete.ts

This file was deleted.

5 changes: 3 additions & 2 deletions components/common/Carousel/carousel.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import { ReactJSXElement } from '@emotion/react/types/jsx-namespace';
import React, { FC, useState } from 'react';
import { AnimatePresence, motion } from 'framer-motion';
import React, { useState } from 'react';

import { TabNavMenu } from '../../navigation/tabNavMenu/tabNavMenu';

interface CarouselProps {
Expand Down Expand Up @@ -36,7 +37,7 @@ const variants = {
* @param props the props passed from the parent component
* @returns
*/
export const Carousel: FC<CarouselProps> = (props: CarouselProps) => {
export const Carousel = (props: CarouselProps) => {
//The card currently being displayed
const [currentCard, setCard] = useState(0);
//The Direction that the card is moving in
Expand Down
44 changes: 31 additions & 13 deletions components/common/ExpandableSearchGrid/expandableSearchGrid.tsx
Original file line number Diff line number Diff line change
@@ -1,16 +1,16 @@
import { useEffect, useState } from 'react';
import { SearchTermCard } from '../SearchTermCard/searchTermCard';
import Card from '@mui/material/Card';
import { CardContent } from '@mui/material';
import { SearchBar } from '../SearchBar/searchBar';
import React from 'react';
import Card from '@mui/material/Card';
import { useRouter } from 'next/router';
import React, { useEffect, useState } from 'react';

import SearchQuery from '../../../modules/SearchQuery/SearchQuery';
import searchQueryLabel from '../../../modules/searchQueryLabel/searchQueryLabel';
import searchQueryColors from '../../../modules/searchQueryColors/searchQueryColors';
import searchQueryLabel from '../../../modules/searchQueryLabel/searchQueryLabel';
import { SearchBar } from '../SearchBar/searchBar';
import { SearchTermCard } from '../SearchTermCard/searchTermCard';

type ExpandableSearchGridProps = {
onChange: Function;
onChange: (searchTerms: SearchQuery[]) => void;
studentTotals: number[];
};

Expand All @@ -23,15 +23,31 @@ export const ExpandableSearchGrid = ({
onChange,
studentTotals,
}: ExpandableSearchGridProps) => {
const router = useRouter();

const [value, setValue] = useState<SearchQuery[]>([]);
const [searchTerms, setSearchTerms] = useState<SearchQuery[]>([]);
const [searchDisabled, setSearchDisable] = useState<boolean>(false);

useEffect(() => {
onChange(searchTerms);
if (router.isReady) {
if (searchTerms.length > 0) {
router.replace(
{
pathname: '/dashboard',
query: { searchTerms: searchQueriesLabel(searchTerms) },
},
undefined,
{ shallow: true },
);
} else {
router.replace('/dashboard', undefined, { shallow: true });
}
}
}, [onChange, searchTerms]);

function addSearchTerm(newSearchTerm: SearchQuery) {
function addSearchTerm(newSearchTerm: SearchQuery | null) {
if (newSearchTerm != null) {
//console.log('adding ' + newSearchTerm + ' to the search terms.');
setSearchTerms([...searchTerms, newSearchTerm]);
Expand Down Expand Up @@ -60,13 +76,11 @@ export const ExpandableSearchGrid = ({
}
}, [searchTerms]);

const router = useRouter();

useEffect(() => {
if (router.isReady) {
setSearchTerms(parseURIEncodedSearchTerms(router.query.searchTerms));
}
}, [router.isReady]);
}, [router.isReady, router.query.searchTerms]);

return (
<div className="w-full min-h-[72px] grid grid-flow-row auto-cols-fr md:grid-flow-col justify-center">
Expand Down Expand Up @@ -103,6 +117,10 @@ function studentTotalFormatter(total: number) {
return total.toLocaleString('en-US') + ' grades';
}

function searchQueriesLabel(queries: SearchQuery[]): string {
return queries.map((query) => searchQueryLabel(query)).join(',');
}

function parseURIEncodedSearchTerms(
encodedSearchTerms: string | string[] | undefined,
): SearchQuery[] {
Expand All @@ -118,7 +136,7 @@ function parseURIEncodedSearchTerms(
}

function parseURIEncodedSearchTerm(encodedSearchTerm: string): SearchQuery {
let encodedSearchTermParts = encodedSearchTerm.split(' ');
const encodedSearchTermParts = encodedSearchTerm.split(' ');
// Does it start with prefix
if (/^([A-Z]{2,4})$/.test(encodedSearchTermParts[0])) {
// If it is just the prefix, return that
Expand All @@ -143,7 +161,7 @@ function parseURIEncodedSearchTerm(encodedSearchTerm: string): SearchQuery {
}
// Is the second part a course number and section
else if (/^([0-9A-Z]{4}\.[0-9A-Z]{3})$/.test(encodedSearchTermParts[1])) {
let courseNumberAndSection: string[] =
const courseNumberAndSection: string[] =
encodedSearchTermParts[1].split('.');
if (encodedSearchTermParts.length == 2) {
return {
Expand Down
Loading

0 comments on commit bad55ce

Please sign in to comment.