Skip to content

Commit

Permalink
refactor(goalpages): Refine styles, remove unused code.
Browse files Browse the repository at this point in the history
  • Loading branch information
ZL-Asica committed Nov 7, 2024
1 parent a5372fb commit ea9e809
Show file tree
Hide file tree
Showing 7 changed files with 24 additions and 69 deletions.
13 changes: 6 additions & 7 deletions src/components/Home/MicroGoal.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -8,20 +8,20 @@ import { ExpandLess, ExpandMore } from '@mui/icons-material'
import {
Box,
Collapse,
Divider,
IconButton,
List,
Paper,
Typography,
} from '@mui/material'

const MicroGoal = ({ microGoal, macroGoalIndex, microGoalIndex }) => {
const { addTask, toggleMicroGoalExpansion, toggleTaskCompletion } =
useGoalsUpdater()
const { addTask, toggleExpansion, toggleTaskCompletion } = useGoalsUpdater()
const progress = calculateProgress([microGoal])

return (
<Paper
elevation={1}
elevation={5}
sx={{ p: 1, mb: 2, bgcolor: 'background.default', borderRadius: 1 }}
>
<Box display='flex' alignItems='center'>
Expand All @@ -34,16 +34,15 @@ const MicroGoal = ({ microGoal, macroGoalIndex, microGoalIndex }) => {
microGoalIndex={microGoalIndex}
/>
<IconButton
onClick={() =>
toggleMicroGoalExpansion(macroGoalIndex, microGoalIndex)
}
onClick={() => toggleExpansion(macroGoalIndex, microGoalIndex)}
size='small'
>
{microGoal.expanded ? <ExpandLess /> : <ExpandMore />}
</IconButton>
</Box>
<Collapse in={microGoal.expanded} timeout='auto' unmountOnExit>
<List sx={{ pl: 2 }}>
<Divider sx={{ mt: 2 }} />
<List sx={{ pl: 2, pb: 3 }}>
{microGoal.tasks.map((task, taskIndex) => (
<Task
key={taskIndex}
Expand Down
26 changes: 1 addition & 25 deletions src/hooks/useGoalsUpdater.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,6 @@ describe('useGoalsUpdater', () => {
expect(user.goals).toContainEqual({
name: goalName,
category,
expanded: false,
microgoals: [],
})

Expand Down Expand Up @@ -129,28 +128,6 @@ describe('useGoalsUpdater', () => {
)
})

it('should toggle goal expansion', async () => {
const goalIndex = 0

// Add initial goal to user data
user.goals.push({
name: 'Goal 1',
category: '#000000',
expanded: false,
microgoals: [],
})

await goalsUpdater.toggleGoalExpansion(goalIndex)

expect(user.goals[goalIndex].expanded).toBe(true)

expect(updateProfile).toHaveBeenCalledWith(
expect.objectContaining({
goals: user.goals,
})
)
})

it('should toggle microgoal expansion', async () => {
const goalIndex = 0
const microGoalIndex = 0
Expand All @@ -159,11 +136,10 @@ describe('useGoalsUpdater', () => {
user.goals.push({
name: 'Goal 1',
category: '#000000',
expanded: false,
microgoals: [{ name: 'MicroGoal 1', expanded: false, tasks: [] }],
})

await goalsUpdater.toggleMicroGoalExpansion(goalIndex, microGoalIndex)
await goalsUpdater.toggleExpansion(goalIndex, microGoalIndex)

expect(user.goals[goalIndex].microgoals[microGoalIndex].expanded).toBe(true)

Expand Down
2 changes: 1 addition & 1 deletion src/hooks/useGoalsUpdater/addOperations.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import { updateGoalsAndStreak } from './updateHelpers'
export const addGoal = async (userContext, goalName, category) => {
const updatedGoals = [
...userContext.user.goals,
{ name: goalName, category, expanded: false, microgoals: [] },
{ name: goalName, category, microgoals: [] },
]
await updateGoalsAndStreak(
userContext,
Expand Down
12 changes: 1 addition & 11 deletions src/hooks/useGoalsUpdater/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -55,24 +55,14 @@ const useGoalsUpdater = () => {
toggleTaskCompletion: (goalIndex, microGoalIndex, taskIndex) =>
toggleTaskCompletion(userContext, goalIndex, microGoalIndex, taskIndex),

/**
* Toggles the expansion status of a specified goal.
* @param {number} goalIndex - Index of the goal.
* @returns {Promise<void>}
*/
toggleGoalExpansion: (goalIndex) => toggleExpansion(userContext, goalIndex),

/**
* Toggles the expansion status of a specified microgoal.
* @param {number} goalIndex - Index of the goal.
* @param {number} microGoalIndex - Index of the microgoal.
* @returns {Promise<void>}
*/
toggleMicroGoalExpansion: (goalIndex, microGoalIndex) =>
toggleExpansion: (goalIndex, microGoalIndex) =>
toggleExpansion(userContext, goalIndex, microGoalIndex),

// Gets list of goals for current user
goals: user.goals,
}
}

Expand Down
7 changes: 2 additions & 5 deletions src/hooks/useGoalsUpdater/toggleOperations.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,13 +23,10 @@ export const toggleTaskCompletion = async (
export const toggleExpansion = async (
userContext,
goalIndex,
microGoalIndex = undefined
microGoalIndex
) => {
const updatedGoals = [...userContext.user.goals]
const target =
microGoalIndex !== undefined
? updatedGoals[goalIndex].microgoals[microGoalIndex]
: updatedGoals[goalIndex]
const target = updatedGoals[goalIndex].microgoals[microGoalIndex]
target.expanded = !target.expanded
await updateGoalsAndStreak(
userContext,
Expand Down
31 changes: 12 additions & 19 deletions src/pages/GoalDetails.jsx
Original file line number Diff line number Diff line change
@@ -1,29 +1,22 @@
import AddItem from '@/components/Home/AddItem'
import MicroGoal from '@/components/Home/MicroGoal'
import ProgressIndicator from '@/components/Home/ProgressIndicator'
import { useUser } from '@/contexts/UserContext'
import useGoalsUpdater from '@/hooks/useGoalsUpdater'
import { calculateProgress } from '@/utils/calculateProgress'
import { Box, CircularProgress, List, Paper, Typography } from '@mui/material'
import { Box, List, Paper, Typography } from '@mui/material'
import { useParams } from 'react-router-dom'

const GoalDetails = () => {
const { macroGoalIndex } = useParams()
const { goals, addMicrogoal } = useGoalsUpdater()
const { user } = useUser()
const { addMicrogoal } = useGoalsUpdater()

// Check if goals are loaded and the specific goal exists
if (!goals || !goals[macroGoalIndex]) {
return (
<Box display='flex' justifyContent='center' mt={4}>
<CircularProgress />
</Box>
)
}

const macroGoal = goals[macroGoalIndex]
const macroGoal = user.goals[macroGoalIndex]
const progress = calculateProgress(macroGoal.microgoals)

return (
<Box sx={{ p: 2 }}>
<Box sx={{ p: 4 }}>
<Paper
elevation={3}
sx={{
Expand All @@ -42,7 +35,12 @@ const GoalDetails = () => {
</Box>
</Paper>

<List>
<AddItem
label='New MicroGoal'
onAdd={(microGoalName) => addMicrogoal(macroGoalIndex, microGoalName)}
/>

<List sx={{ mt: 3 }}>
{macroGoal.microgoals.map((microGoal, microGoalIndex) => (
<MicroGoal
key={microGoalIndex}
Expand All @@ -52,11 +50,6 @@ const GoalDetails = () => {
/>
))}
</List>

<AddItem
label='New MicroGoal'
onAdd={(microGoalName) => addMicrogoal(macroGoalIndex, microGoalName)}
/>
</Box>
)
}
Expand Down
2 changes: 1 addition & 1 deletion src/pages/Home.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ const Home = () => {
const { addGoal } = useGoalsUpdater()

return (
<Box sx={{ maxWidth: 800, margin: 'auto', padding: 2 }}>
<Box sx={{ maxWidth: 800, margin: 'auto', padding: 3 }}>
<AddItem label='New Goal' onAdd={addGoal} />

{/* Render existing goals */}
Expand Down

0 comments on commit ea9e809

Please sign in to comment.