From 3910db13a821b2cf95ec178339f63f3f2977b040 Mon Sep 17 00:00:00 2001 From: ZL Asica <40444637+ZL-Asica@users.noreply.github.com> Date: Thu, 7 Nov 2024 12:26:26 -0600 Subject: [PATCH] doc(README): Add `Keeping Up-to-Date with `origin/main`` section. --- README.md | 178 +++++++++++++++++++++++++++++++++++++++--------------- 1 file changed, 128 insertions(+), 50 deletions(-) diff --git a/README.md b/README.md index 825d673..d6e83fd 100644 --- a/README.md +++ b/README.md @@ -5,13 +5,14 @@ ## Table of Contents 1. [File Structure and Logic](#1-file-structure-and-logic) -2. [Context](#2-context) +2. [Keeping Up-to-Date with `origin/main`](#2-keeping-your-work-up-to-date-with-originmain) +3. [Context](#3-context) - [What is Context?](#1-what-is-context) - [Why Use Context Instead of Hooks?](#2-why-use-context-instead-of-hooks) - [How to Use UserContext](#3-how-to-use-usercontext) - [Accessing User Data](#accessing-user-data) - [Updating User Data](#updating-user-data) -3. [useGoalsUpdater](#3-usegoalsupdater-hook) +4. [useGoalsUpdater](#4-usegoalsupdater-hook) - [Overview](#overview) - [Dependencies](#dependencies) - [Functions](#functions) @@ -28,25 +29,104 @@ This project uses a component-based structure with a focus on clear separation o . ├── LICENSE ├── README.md # Project documentation and usage guide -├── eslint.config.mjs +├── prettier.config.cjs # Prettier configuration file +├── eslint.config.mjs # Eslint configuration file +├── vite.config.js # Vite configuration file +├── jsconfig.json # Javascript config file ├── firebase.json # Firebase configuration for hosting ├── package.json # Dependencies -├── src # Source code -│ ├── components # Shared components and features -│ │ └── common # Common components used across the app -| | └── Home # Home page components -| | └── Streak # Streak page components -│ ├── contexts # Contexts for managing global app state -│ │ └── UserContext.jsx # Provides user authentication data globally -│ ├── hooks # Custom hooks for specialized logic -│ ├── pages # Application pages -│ └── utils # Utility functions and Firebase configurations -└── vite.config.js # Vite configuration for project bundling (shortcuts) +└── src # Source code + ├── components # Shared components and features + │ └── common # Common components used across the app + | └── Home # Home page components + | └── Streak # Streak page components + ├── contexts # Contexts for managing global app state + │ └── UserContext.jsx # Provides user authentication data globally + ├── hooks # Custom hooks for specialized logic + │ └── useGaolsUpdater # All goals related hooks + ├── pages # Application pages + ├── utils # Utility functions and Firebase configurations + └── styles # Styles. ``` The main components and utilities are organized under `src/components` and `src/utils`, while `UserContext` manages user state globally to avoid redundant data fetching. -## 2. Context +## 2. Keeping Your Work Up-to-Date with `origin/main` + +### Step 1: Create a New Feature Branch + +- **Why**: Avoid developing directly on `main`. Keeping `main` in sync with `origin/main` makes it easier to update and manage changes. +- **How**: Create and switch to a new branch for your feature, and remember to push it to `origin`: + + ```bash + git switch -c feat/new-feature-name + git push -u origin feat/new-feature-name + ``` + +### Step 2: Update Your Local `main` with `origin/main` + +1. **Switch Back to `main`**: Ensure you're on `main` before updating: + + ```bash + git switch main + ``` + +2. **Stash Your Work**(if needed): If you have uncommitted changes, stash them to avoid conflicts while pulling: + + ```bash + git stash + ``` + +3. **Pull Latest Changes**: Bring in the latest updates from `origin/main`: + + ```bash + git pull origin main + ``` + +### Step 3: Rebase Your Feature Branch onto the Updated `main` + +1. **Switch Back to Your Feature Branch**: + + ```bash + git switch feat/new-feature-name + ``` + +2. **Rebase**: Apply your feature branch changes on top of the latest `main`: + + ```bash + git rebase main + ``` + +3. **Apply Stash**(if you stashed changes): Reapply your saved changes once main is updated: + + ```bash + git stash pop + ``` + +4. **Resolve Conflicts** (if any): If conflicts occur, Git will prompt you to resolve them. After resolving, use: + + ```bash + git add + git rebase --continue + ``` + +5. **Push Changes**: + + - **If you have NOT previously pushed code to the remote**: + + ```bash + git push + ``` + + - **If you HAVE previously pushed code** (with conflicting changes), you may need to force-push to align with the rebased history. **(Do NOT use this on `main`)** + + ```bash + git push --force-with-lease + ``` + +By following these steps, you ensure that `main` remains in sync with `origin/main`, while your feature branch incorporates the latest updates without directly modifying `main`. This keeps your work organized and minimizes conflict risks. + +## 3. Context ### 1. What is Context? @@ -63,24 +143,22 @@ In our previous `StudyBuddy` project, we relied on hooks to fetch user data dire 1. **Enable Global UserContext**: `UserProvider` has already been implemented to wrap the main application in `App.jsx`. This enables `UserContext` throughout the app. ```jsx - import { UserProvider } from '@contexts/UserContext'; + import { UserProvider } from '@contexts/UserContext' - const App = () => ( - - {/* App Components */} - - ); + const App = () => {/* App Components */} ``` 2. **Access User Data in Components**: Use the `useUser` hook to access user data (anything inside their profile you can all access just by e.g. `user.goals`) and authentication functions in any component: ```jsx - import { useUser } from '@contexts/UserContext'; - + import { useUser } from '@contexts/UserContext' + const MyComponent = () => { - {/* You can decide what to use from `useUser` */} - const { user, loading, handleSignIn, handleSignOut } = useUser(); - + { + /* You can decide what to use from `useUser` */ + } + const { user, loading, handleSignIn, handleSignOut } = useUser() + return user ? (

Welcome, {user.displayName}

@@ -88,22 +166,22 @@ In our previous `StudyBuddy` project, we relied on hooks to fetch user data dire
) : ( - ); - }; + ) + } ``` #### Updating User Data Use the `updateProfile` function to update user profile information: - ```jsx - const { updateProfile } = useUser(); - updateProfile({ displayName: 'New Name' }); - ``` +```jsx +const { updateProfile } = useUser() +updateProfile({ displayName: 'New Name' }) +``` The `updateProfile` function accepts an object with updated user fields and syncs them with both the context and Firebase, ensuring efficient data sharing across components and reducing the need for direct database access. -## 3. useGoalsUpdater Hook +## 4. useGoalsUpdater Hook ### Overview @@ -125,42 +203,42 @@ This hook enables efficient management of goal-related actions across components #### Adding items -- **addGoal**: Adds a new goal with a specified name. +- **addGoal**: Adds a new goal with a specified name, and category (HEX color code). ```jsx -addGoal("New Goal Name"); +addGoal('New Goal Name', category) ``` - + - **addMicrogoal**: Adds a new microgoal within a specified goal. ```jsx -addMicrogoal(goalIndex, "New Microgoal Name"); +addMicrogoal(goalIndex, 'New Microgoal Name') ``` - -- **addTask**: Adds a new task within a specified microgoal. + +- **addTask**: Adds a new task within a specified microgoal with optional dueDate. ```jsx -addTask(goalIndex, microGoalIndex, "New Task Name"); +addTask(goalIndex, microGoalIndex, 'New Task Name', dueDate?) ``` #### Deleting items -- **deleteGoal**: Deletes a goal. +- **deleteGoal**: Deletes a goal. ```jsx -deleteGoal(goalIndex); +deleteGoal(goalIndex) ``` - + - **deleteMicrogoal**: Deletes a microgoal within a specified goal. ```jsx -deleteMicrogoal(goalIndex, microGoalIndex); +deleteMicrogoal(goalIndex, microGoalIndex) ``` - + - **deleteTask**: Deletes a task within a specified microgoal. ```jsx -deleteTask(goalIndex, microGoalIndex, taskIndex); +deleteTask(goalIndex, microGoalIndex, taskIndex) ``` #### Toggle Task Completion @@ -168,7 +246,7 @@ deleteTask(goalIndex, microGoalIndex, taskIndex); - **toggleTaskCompletion**: Toggles the completion status of a task and updates the streak accordingly. ```jsx -toggleTaskCompletion(goalIndex, microGoalIndex, taskIndex); +toggleTaskCompletion(goalIndex, microGoalIndex, taskIndex) ``` #### Expanding/collapsing items @@ -176,13 +254,13 @@ toggleTaskCompletion(goalIndex, microGoalIndex, taskIndex); - **toggleGoalExpansion**: Toggles the expansion state of a goal. ```jsx -toggleGoalExpansion(goalIndex); +toggleGoalExpansion(goalIndex) ``` - + - **toggleMicroGoalExpansion**: Toggles the expanded/collapsed state of a microgoal within a specified goal. ```jsx -toggleMicroGoalExpansion(goalIndex, microGoalIndex); +toggleMicroGoalExpansion(goalIndex, microGoalIndex) ``` These functions directly update the `UserContext`, ensuring consistent data and logging status messages for clear feedback on each action performed.