This project is a scheduling web application developed in Next.js and TypeScript that allows users to create and manage their schedules. It offers features such as user registration, profile management, connection to Google Calendar and creation of scheduling events.
The application aims to simplify the agenda management process and ensure that users have an efficient and organized way of managing their time. Its value proposition lies in its seamless integration with Google Calendar, its user-friendly interface and its robust scheduling and availability management functionality.
🏷 Reserve your username for later
📅 Seamlessly sync your agenda with Google Calendar integration
👥 Personalize your experience with easy user registration and profile management
➕ Create scheduling events without conflicts and add them into your Google Calendar
🔗 Share your link and watch events pops right into your agenda.
ignite-call.mp4
The layout of the application was designed by Rocketseat and is available on Figma.
The following tools were used to build the project:
* See the package.json file
Before you begin, ensure that you have the following tools installed on your machine: Git, Node.js. It's also good to have an editor to work with the code, such as VSCode.
- Clone the repository:
git clone https://github.com/guipmdev/ignite-call/
- Change to the project directory:
cd ignite-call
- Install the dependencies:
npm install
-
Create a SQL database and note down the connection details
- This can be a local database, a remote database, or even a Docker container
-
Visit Google Cloud Console, create a project, enable Google Calendar API, and, under Credentials, create an OAuth 2.0 client ID, configure the consent screen, and get Client ID and Secret
-
Generate a secure secret key for NextAuth.js
- If you’re on a UNIX system, you can use the command
openssl rand -base64 32
to generate this key
- If you’re on a UNIX system, you can use the command
-
Rename the file
.env.example
to.env
and insert the necessary information:
mv .env.example .env
- Generate the migrations, if necessary:
npx prisma migrate dev
- Push the migrations to the database:
npx prisma db push
- Start the web application:
npm run dev
- Access http://localhost:3000/ to view the application
This project is licensed under the terms of the MIT
license. See the
LICENSE file for additional info.
- Many thanks to Rocketseat for the layout and tips when putting this project together
Made with 💙 by @guipm.dev - Feel free to contact me!