Skip to content

Latest commit

 

History

History
377 lines (260 loc) · 14.3 KB

README.md

File metadata and controls

377 lines (260 loc) · 14.3 KB

Contributors Forks Stargazers Issues MIT License LinkedIn


Logo

Tracker

project_description
Explore the docs »

View Demo · Report Bug · Request Feature

Table of Contents
  1. About The Project
  2. Getting Started
  3. Usage
  4. Roadmap
  5. Contributing
  6. License
  7. Contact
  8. Acknowledgments

About The Project

Product Name Screen Shot

Here's a blank template to get started: To avoid retyping too much info. Do a search and replace with your text editor for the following: github_username, repo_name, twitter_handle, linkedin_username, email_client, email, project_title, project_description

(back to top)

Built With

  • React
  • Tailwind
  • Typescript

(back to top)

Getting Started

This is an example of how you may give instructions on setting up your project locally. To get a local copy up and running follow these simple example steps.

Prerequisites

This is an example of how to list things you need to use the software and how to install them.

  • npm
    npm install npm@latest -g

Continuous Integration (CI)

This project uses CircleCI for Continuous Integration (CI). To set up CircleCI for this repository:

  1. Sign Up for CircleCI:

    • Visit CircleCI and log in using your GitHub account.
  2. Authorize CircleCI:

    • Allow CircleCI to access this repository.
  3. Add the Configuration File:

    • Ensure the .circleci/config.yml file is present in the repository.
    • The current configuration uses Cypress for testing:
      version: 2.1
      orbs:
        cypress: cypress-io/cypress@3.1.1
      workflows:
        build:
          jobs:
            - cypress/run:
                cypress-command: npx cypress run --headless
                start-command: npm start
  4. Verify the CI Pipeline:

    • Push your changes to the main branch.
    • Navigate to the CircleCI dashboard to confirm that tests run successfully.

For more information, see the CircleCI Documentation.

Installation

  1. Get a free API Key at https://example.com
  2. Clone the repo
    git clone https://github.com/github_username/repo_name.git
  3. Install NPM packages
    npm install
  4. Enter your API in config.js
    const API_KEY = 'ENTER YOUR API';
  5. Change git remote url to avoid accidental pushes to base project
    git remote set-url origin github_username/repo_name
    git remote -v # confirm the changes

(back to top)

Design Doc

Currently, we will be using Helvetica Neue Sans-Serif as our primary font, with the font size being set using vh/vw.

Example: className="text-[5vw] font-[Helvetica Neue]"

(Note that most text should be Helvetica Neue by default, but if it isn't, setting it manually can be done as above.)

We will be refactoring to make use of MUI's SvgIcon icons, rather than images. Follow the following links for more information about how we'll be doing this: https://mui.com/material-ui/getting-started/ https://mui.com/material-ui/material-icons/?query=home

We'll be using colors according to the image below. alt text

For a form container, we'll be using something like this: <div className="w-[50vw] mx-auto my-[2vh] p-[3vh] ">

while for our Save Button, we'll be following this example. bg-cyan-600 text-white px-[2vw] py-[1vh] rounded w-[10vw] hover:bg-cyan-700 focus:ring-cyan-500 focus:ring-2

For our form boxes, we'll be using this styling. <label htmlFor="email" className="block text-gray-700 font-medium mb-[1vh]"> Email </label> <input className="w-full px-[1vh] py-[1vh] border border-gray-300 rounded-md focus:outline-none focus:ring-2 focus:ring-cyan-500" name="email"/>

When we get text that's too long for our designated page area, we will cut that text off after a certain point, then insert a "Read More" button. This will open a modal containing the full version of the previously-truncated text.

When creating tables and forms, we'll be alternating between white and grey-100 for the background, and when we wish to create a button or search bars, we'll generally style them like this unless specifically told otherwise:

<button className='bg-cyan-600 text-white p-[1vh] rounded w-[10vw]'>Add New +</button>

<input className='p-[1vh] border-2 border-slate-800 rounded w-[12vw] h-full' />

<input className='p-[1vh] border-2 border-slate-800 rounded w-[12vw] h-full' />

For an example of what this might look like in practice, see below.

alt text

Implementing User Context With React's Context Hook

Benefits

User Context has been implemented!! The use case for the context is getting access to a specific user's information and rather that doing a nightmare of imports and notations to get the info you need; you can call one line of code and get access to the session token for fetches and the loggedIn state for rendering! It keeps the code light, DRY, and easy to develope! Currently there are six pieces of info being given by the context. should there be a need / use case for adding more things to that we can add that at a later date! Please DM Charles for now and we can come up with a plan!

Right up front, here is a guide for implementation:

PRE REQS: The only requirement is that your component is being proprerly rendered in 'App.tsx' so make sure to check that first.

  1. Import useUserLoggedContext into your component page:

import { useUserLoggedContext } from './context/UserLoggedContext.tsx';

  1. Destructure the function call INSIDE your component declaration:

const { token, roles, isLoggedIn, userLogged, clearUserLogged } = useUserLoggedContext();

  1. Use the whatever part of the context you need!

Usage

Use this space to show useful examples of how a project can be used. Additional screenshots, code examples and demos work well in this space. You may also link to more resources.

For more examples, please refer to the Documentation

(back to top)

Roadmap

Feature 1 - Login

Feature 2 - Home

Feature 3 - Companies

The Companies section allows users to seamlessly manage a list of their companies.

Key Functionalities Include:

  • View All Companies: Browse a comprehensive list of companies with detailed information such as company name, application status, and notes.
  • View Company Details: Click on a company to see detailed information on a dedicated page, including the company’s name, website, address, and notes. The details page also displays a list of associated contacts, making it easier to manage relationships and connections.
  • Create a Company: Add new companies by filling out a simple form with fields like name, website, address, and notes.
  • Search for a Company: Use the search bar to quickly find companies by name, enhancing efficiency and user experience.

Companies Section Demo

(back to top)

Contributing

Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.

If you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement". Don't forget to give the project a star! Thanks again!

  1. Fork the Project
  2. Create your Feature Branch (git checkout -b feature/AmazingFeature)
  3. Commit your Changes (git commit -m 'Add some AmazingFeature')
  4. Push to the Branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

(back to top)

Core Contributors:

Cirbo, Candice

De La Rosa, Melchor

Chirchirillo, Joe

Macur, Jim

Messersmith, Renee

License

Distributed under the MIT License. See LICENSE.txt for more information.

(back to top)

Acknowledgments

(back to top)