Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/brunomoleta/investment-app-client
Frontend app for connecting investors and investment advisors.
https://github.com/brunomoleta/investment-app-client
mobile-first nextjs radix-ui react styled-components typescript
Last synced: 22 days ago
JSON representation
Frontend app for connecting investors and investment advisors.
- Host: GitHub
- URL: https://github.com/brunomoleta/investment-app-client
- Owner: brunomoleta
- Created: 2024-02-06T11:49:42.000Z (12 months ago)
- Default Branch: master
- Last Pushed: 2024-03-28T20:48:48.000Z (10 months ago)
- Last Synced: 2024-11-07T03:16:03.485Z (2 months ago)
- Topics: mobile-first, nextjs, radix-ui, react, styled-components, typescript
- Language: TypeScript
- Homepage: https://easybank-investments.vercel.app/
- Size: 7.43 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Easybank frontend app
## Description
Frontend of a fullstack app that connects investors and investment advisors.
The goal of this aplication was to make my first fullstack app using Next.js.
## Table of contents
- [Overview](#overview)
- [Built with](#built-with)
- [Design](#design)
- [User flow](#user-flow)
- [Deploy links](#deploy-links)
- [Project Structure](#project-structure)
- [Scripts](#scripts)
- [Dependencies](#dependencies)
- [Dev dependencies](#dev-dependencies)
- [Installation](#installation)
- [Run the app locally](#run-the-app-locally)
- [Architecture](#architecture)
- [The process](#the-process)
- [What Bruno learned](#what-bruno-learned)
- [Continued development](#continued-development)
- [Useful resources](#useful-resources)
- [Acknowledgments](#acknowledgments)
- [Author](#author)
## Overview
### Built with
#### React related
- Next.js
- Cookies
- Typescript
- React context#### Others
- Axios
- Styled components
- Radix UI### Design
#### User flow
- The first screen is the homepage. When you click "Entrar"
and enter the second screen.
- Here you identify as either an advisor or an investor.![](./src/assets/documentation/01-02.png)
- Screens 3 and 4 is where you insert e-mail and password separately.
![](./src/assets/documentation/03-04.png)
- At 5 is the investor user logged in dashboard;
- At last, you can edit their password after validating the current one;
![](./src/assets/documentation/05-06.png)
## Deploy links
- Frontend deploy: [Live App](https://easybank-investments.vercel.app/)
- Backend deploy: [Backend](https://investment-fullstack.onrender.com/)
## Project structure
First, run the development server:
```bash
npm run dev
# or
yarn dev
# or
pnpm dev
# or
bun dev
```Open [http://localhost:3000](http://localhost:3000) with your browser to see the result.
## Scripts
- `dev`: Inicia o ambiente de desenvolvimento usando o Vite.
- `build`: Usado para construir o aplicativo para produção.
- `lint`: Executa o ESLint para linting e correção automática.Execute os scripts utilizando `npm run` ou `yarn run`.
## Dependencies
- ````@hookform/resolvers````: ^3.3.4,
- ````@radix-ui/react-dialog````: ^1.0.5,
- ````@radix-ui/react-dropdown-menu````: ^2.0.6,
- ````@radix-ui/react-icons````: ^1.3.0,
- ````axios````: ^1.6.7,
- ````babel-plugin-styled-components````: ^2.1.4,
- ````nanoid````: ^5.0.5,
- ````next````: 14.1.0,
- ````react````: ^18,
- ````react-dom````: ^18,
- ````react-feather````: ^2.0.10,
- ````react-hook-form````: ^7.50.1,
- ````react-toastify````: ^10.0.4,
- ````styled-components````: ^6.1.8,
- ````yarn````: ^1.22.21,
- ````zod````: ^3.22.4## Dev dependencies
- ``@swc/plugin-styled-components``: ^1.5.116,
- ``@testing-library/jest-dom``: ^6.4.0,
- ``@testing-library/react``: ^14.1.2,
- ``@types/node``: ^20,
- ``@types/react``: ^18,
- ``@types/react-dom``: ^18,
- ``autoprefixer``: ^10.0.1,
- ``eslint``: ^8,
- ``eslint-config-next``: 14.1.0,
- ``jest``: ^29.7.0,
- ``jest-environment-jsdom``: ^29.7.0,
- ``new-component``: ^5.0.2,
- ``postcss``: ^8,
- ``tailwindcss``: ^3.3.0,
- ``typescript``: ^5"## Installation
1. Clone the frontend repo:
```bash
git clone [email protected]:brunomoleta/Investment-app-client.git
```2. Clone the backend repo or use :
```bash
git clone [email protected]:brunomoleta/Investment-app-server.git
```3. Install the dependencies:
```bash
npm install# ou
yarn install
```### Run the app locally
Run the following command to execute the app:
```bash
# development
yarn dev# production
yarn build
```### Architecture
```
investing-app-client/
│
├── node_modules/ Dependencies installed in your local environment.
│
├── public/ Public files.
│
├── lib/ Includes a file to set up Styled-components.
│
├── src/ Source code
│ ├── app/ Routes;
│ ├── assets/ Static resources such as images, logos and illustrations;
│ ├── components/ React components;
│ ├── providers/ Componentes de gerenciamento de estado global;
│ ├── schemas/ Data validation context;
│ ├── hooks/ Hook functions;
│ ├── services/ API communication service, data and helper functions.
│ ├── styled-components/Styled-components components;
│ ├── types/ Component types;
│ └── ...
```
## The process
- Started creating multistep forms both for the advisor and for the investor users;
- Continued making the homepage and signed in and login pages for the mobile width;
- Created the dashboards for the logged users;
- Set an authenticator, so it's not possible that an unauthorized user accesses a dashboard;
- Improved the UI for the desktop user;### What Bruno learned
#### Multi step form
A code highlight is the multistep form. It renders a component depending on the ````step```` it's at.
At each time the user sends data, the state adds 1 to the ````step````.
The final result is:```tsx
function SignInForm({userType}: { userType: UserType }) {
const {step} = useUtilsContext() as IUtilsContext;return (
<>
{step === 0 && }
{step === 1 && }
{step === 2 && }
{step === 3 && }{step === 4 && userType === "investor" && }
{step === 4 && userType === "advisor" && }{step === 5 && userType === "investor" && }
{step === 5 && userType === "advisor" && }{step === 6 && userType === "investor" && }
{step === 6 && userType === "advisor" && }{step === 7 && userType === "advisor" && }
>
);
}
```This is a snippet of when the form is sent with React Hook Form validated with Zod.
It adds the current data to the ````formInfo```` state:```tsx
async function onSubmit(formData: IBio) {
setFormInfo({...formInfo, ...formData});
await getInvestmentTypesNoAuth();setStep((prevStep) => prevStep + 1);
}
```### Continued development
Use Next.js further in the server as at this project the feature is used only with the cookies authorization.
### Useful resources
- [Josh Cameau's blog](https://www.joshwcomeau.com/) - The best frontend blog I know by far;
- [Radix UI](https://www.radix-ui.com/) - It saved me time from developing components such as the Dropdown and the modal
dialog;
- [Android Mobile PSD Mockup](https://www.freepik.com/free-psd/smartphone-mockup_2103881.htm#query=android%20mockup&position=33&from_view=keyword&track=ais&uuid=cafff37a-0d2f-4d89-8e60-a62c1b805ac2) -
Template so you can take a screenshot of the app and inserted in Photoshop;
## Acknowledgments
### Author
- Github - [Bruno Moleta](https://github.com/brunomoleta)
- Frontend Mentor - [@brunomoleta](https://www.frontendmentor.io/profile/brunomoleta)
- LinkedIn - [@brunomoleta](https://www.linkedin.com/in/bruno-moleta-santos/)
- Email - [email protected]