Skip to content

Commit

Permalink
Border outline of select term stays white and aligned, padded component
Browse files Browse the repository at this point in the history
  • Loading branch information
manhualu committed Oct 26, 2023
1 parent 19d5dcd commit 61566f2
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 41 deletions.
8 changes: 2 additions & 6 deletions client/src/components/navbar/Navbar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,6 @@ import Privacy from './Privacy';
import Settings from './Settings';
import TermSelect from './TermSelect';


const LogoImg = styled('img')`
height: 46px;
margin-right: 12.5px;
Expand All @@ -37,7 +36,6 @@ const NavbarTitle = styled(Typography)`
z-index: 1201;
`;


const Navbar: React.FC = () => {
const [currLogo, setCurrLogo] = useState(notanglesLogo);

Expand All @@ -51,9 +49,7 @@ const Navbar: React.FC = () => {
onMouseOver={() => setCurrLogo(notanglesLogoGif)}
onMouseOut={() => setCurrLogo(notanglesLogo)}
/>
<NavbarTitle variant="h6">
Notangles
</NavbarTitle>
<NavbarTitle variant="h6">Notangles</NavbarTitle>
<TermSelect />
<CustomModal
title="About"
Expand All @@ -71,7 +67,7 @@ const Navbar: React.FC = () => {
<CustomModal title="Settings" showIcon={<SettingsIcon />} description={'Settings'} content={<Settings />} />
</Toolbar>
</StyledNavBar>
</NavbarBox >
</NavbarBox>
);
};

Expand Down
77 changes: 42 additions & 35 deletions client/src/components/navbar/TermSelect.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,29 +4,35 @@ import React, { useContext } from 'react';
import { ThemeType } from '../../constants/theme';
import { AppContext } from '../../context/AppContext';
import { CourseContext } from '../../context/CourseContext';
import { styled } from '@mui/system';

const StyledSelect = styled(Select)(({ theme }) => ({
'& .MuiOutlinedInput-notchedOutline': {
borderColor: 'white',
},
'.MuiSelect-icon': {
color: 'white',
},
'&:focus': {
'& .MuiOutlinedInput-notchedOutline': {
borderColor: 'white',
},
},
}));

const TermSelect: React.FC = () => {
const { term, termName, setTermName, year, setTerm, setYear, setSelectedTimetable, displayTimetables, termsData } =
useContext(AppContext);

const {
term,
termName,
setTermName,
year,
setTerm,
setYear,
setSelectedTimetable,
displayTimetables,
termsData
} = useContext(AppContext);

const { setSelectedCourses, setSelectedClasses, setCreatedEvents } =
useContext(CourseContext);
const { setSelectedCourses, setSelectedClasses, setCreatedEvents } = useContext(CourseContext);

const theme = useTheme<ThemeType>();
const isMobile = useMediaQuery(theme.breakpoints.down('sm'));

const termData = new Set([termsData.prevTerm.termName.concat(', ', termsData.prevTerm.year), termsData.newTerm.termName.concat(', ', termsData.newTerm.year)]);
const termData = new Set([
termsData.prevTerm.termName.concat(', ', termsData.prevTerm.year),
termsData.newTerm.termName.concat(', ', termsData.newTerm.year),
]);

const selectTerm = (e: any) => {
const defaultStartTimetable = 0;
Expand All @@ -35,9 +41,9 @@ const TermSelect: React.FC = () => {
let termNum = 'T' + newTermName.split(' ')[1];
let newYear = e.target.value.split(', ')[1];

if (e.target.value.includes("Summer")) {
if (e.target.value.includes('Summer')) {
// This is a summer term.
termNum = "Summer";
termNum = 'Summer';
}

setTerm(termNum);
Expand All @@ -47,29 +53,30 @@ const TermSelect: React.FC = () => {
setSelectedClasses(displayTimetables[termNum][defaultStartTimetable].selectedClasses);
setCreatedEvents(displayTimetables[termNum][defaultStartTimetable].createdEvents);
setSelectedCourses(displayTimetables[termNum][defaultStartTimetable].selectedCourses);
}
};

return (
<FormControl>
<InputLabel sx={{ marginTop: 1, color: 'white' }}>Select your term</InputLabel>
<Select
label="Select your term"
<FormControl sx={{ paddingRight: '15px' }}>
<InputLabel id="select-term-label" sx={{ color: 'white' }}>
Select term
</InputLabel>
<StyledSelect
size="small"
labelId="select-term-label"
id="select-term"
sx={{ color: 'white' }}
label="Select term"
value={isMobile ? term : termName.concat(', ', year)}
sx={{
marginTop: 1,
color: 'white',
'.MuiSelect-icon': {
color: 'white'
},
}}
onChange={selectTerm}
>
{
Array.from(termData).map((term, index) => {
return <MenuItem key={index} value={term}>{term}</MenuItem>;
})
}
</Select>
{Array.from(termData).map((term, index) => {
return (
<MenuItem key={index} value={term}>
{term}
</MenuItem>
);
})}
</StyledSelect>
</FormControl>
);
};
Expand Down

0 comments on commit 61566f2

Please sign in to comment.