Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/arturcolen/plann.er
Projects developed during NLW Journey, a week-long Rocketseat event focused on creating a complete application through intensive, hands-on lessons.
https://github.com/arturcolen/plann.er
axios dayjs fastify nlw nodejs nodemailer prisma reactjs tailwindcss trip typescript zod
Last synced: 16 days ago
JSON representation
Projects developed during NLW Journey, a week-long Rocketseat event focused on creating a complete application through intensive, hands-on lessons.
- Host: GitHub
- URL: https://github.com/arturcolen/plann.er
- Owner: ArturColen
- License: mit
- Created: 2024-07-10T00:34:53.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2025-01-03T21:00:54.000Z (20 days ago)
- Last Synced: 2025-01-03T21:25:44.061Z (20 days ago)
- Topics: axios, dayjs, fastify, nlw, nodejs, nodemailer, prisma, reactjs, tailwindcss, trip, typescript, zod
- Language: TypeScript
- Homepage:
- Size: 1.39 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
plann.er
The project is a complete travel itinerary platform with front-end and back-end components. Its primary goal is to simulate a system for scheduling and managing trips, offering features such as activity tracking and participant management. This project was developed during the NLW Journey, a Rocketseat event, as a way to enhance knowledge of web development using Node.js and TypeScript.
## π Table of Contents
- [About](#about)
- [Table of Contents](#table-of-contents)
- [Features](#features)
- [Application Demonstration](#application-demonstration)
- [Setup and Run the Application](#setup-and-run-the-application)
- [Technologies](#technologies)
- [Author](#author)
- [License](#license)## π Features
All API routes for the listed features have been fully developed and are functional. However, as this project is for educational purposes, some features were not implemented in the front-end during the course and currently have no timeline for implementation. Below is a detailed list of the features, indicating which ones have been implemented and which ones remain unavailable on the front-end.
- [x] Travel registration
- [x] Travel activity registration
- [x] Creation of travel invitations
- [x] Travel confirmation
- [x] Participant confirmation
- [x] Travel details listing
- [x] Participants listing
- [ ] Travel data update
- [ ] Manage registered guests
- [ ] Registration of important travel links
- [ ] Listing of important travel links## π² Application Demonstration
Below, you will find example images of the applicationβs front-end, showcasing its main screens and highlighting its interface and core functionalities. Additionally, you can access the API documentation for detailed information about the available routes. To view the documentation, [click here](https://nlw-journey.apidocumentation.com/reference).
- Trip Creation
![Trip Creation](./resources/screenshots/trip-creation.png)
- Confirm Trip Creation
![Confirm Trip Creation](./resources/screenshots/confirm-trip-creation.png)
- Trip Details
![Trip Details](./resources/screenshots/trip-details.png)
- Register Trip Activity
![Register Trip Activity](./resources/screenshots//register-activity.png)
## π Setup and Run the Application
### βοΈ Prerequisites
Before starting, you need to have the following tools installed on your machine: [Git](https://git-scm.com) and [Node.js](https://nodejs.org/en).
Itβs also recommended to use a code editor like [Visual Studio Code](https://code.visualstudio.com/).
### π How to Run the Application
#### Front-End Setup
```bash
# Clone this repository
$ git clone https://github.com/ArturColen/plann.er.git# Navigate to the client folder
$ cd client# Install dependencies
$ npm install# Run the application in development mode
$ npm run dev# The front-end will start on port 5173 - access
```#### Back-End Setup
```bash
# Open a new terminal and navigate to the server folder
$ cd server# Install dependencies
$ npm install# Copy the contents of the .env.example file to a new .env file
$ cp .env.example .env# Create the database file
$ npx prisma db push# Run the server in development mode
$ npm run dev# The server will start on port 3333 - it should log `Server is running on port 3333`
```## π» Technologies
The following tools and frameworks were used in the development of this project:
- [**Node.js**](https://nodejs.org/docs/latest/api): A JavaScript runtime that allows the development of scalable and high-performance server-side applications.
- [**TypeScript**](https://www.typescriptlang.org/docs): A strongly typed programming language that builds on JavaScript, adding static types and improving code quality.
- [**React.js**](https://react.dev/learn): A popular JavaScript library for building interactive and component-based user interfaces.
- [**Axios**](https://axios-http.com/docs/intro): A promise-based HTTP client for making API requests, with built-in support for interceptors and error handling.
- [**Tailwind CSS**](https://v2.tailwindcss.com/docs): A utility-first CSS framework for rapidly styling modern user interfaces.
- [**Fastify**](https://fastify.dev/docs/latest): A fast and low-overhead web framework for building APIs and back-end services in Node.js.
- [**Prisma**](https://www.prisma.io/docs): An ORM (Object-Relational Mapper) for managing database schema and queries with a focus on developer productivity.
- [**Nodemailer**](https://www.nodemailer.com): A tool for sending emails from Node.js applications, supporting multiple transport methods.
- [**Day.js**](https://day.js.org/docs/en/display/format): A lightweight library for parsing, validating, manipulating, and formatting dates.
- [**Zod**](https://zod.dev): A schema validation library for defining and validating the shape of data, commonly used in APIs and forms.## π¨π»βπ» Author
---
| [
Artur Bomtempo](https://arturbomtempo.dev/) |
| :--------------------------------------------------------------------------------------------------------------------------------------------------: |Developed by Artur Bomtempo ππ½. Get in touch:
[![Gmail Badge](https://img.shields.io/badge/[email protected]?style=flat-square&logo=Gmail&logoColor=white&link=mailto:[email protected])](mailto:[email protected])
[![LinkedIn Badge](https://img.shields.io/badge/-Artur%20Bomtempo-0A66C2?style=flat-square&logo=LinkedIn&logoColor=white&link=https://www.linkedin.com/in/artur-bomtempo/)](https://www.linkedin.com/in/artur-bomtempo/)
[![Instagram Badge](https://img.shields.io/badge/[email protected]?style=flat-square&logo=Instagram&logoColor=white&link=https://www.instagram.com/arturbomtempo.dev/)](https://www.instagram.com/arturbomtempo.dev/)## π License
Copyright (c) 2025 Artur Bomtempo Colen
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.