freeCodeCamp.org is a friendly community where you can learn to code for free. It is run by a donor-supported 501(c)(3) nonprofit to help millions of busy adults transition into tech. Our community has already helped more than 40,000 people get their first developer job. Our full-stack web development and machine learning curriculum is completely free and self-paced. We have thousands of interactive coding challenges to help you expand your skills.
A self-hosted solution to help teachers plan and manage classroom-based learning, on top of freeCodeCamp's learning platform.
For a while now teachers have been asking for a way to get a birds eye view of multiple students who are progressing through the course. This is why we set out to make freeCodeCamp classroom mode, an interactive dashboard for teachers to view multiple freeCodeCamp users’ progress on their courses.
If you have used GitHub Codespaces in other projects, doing the same in freeCodeCamp Classroom should be straightforward.
-
If you want a ready-made dev environment in your browser, make a fork of this repository.
-
Afterward, set up your NextAuth-related environment variables in the
.env
file. -
Please follow the "Setup Instructions" in the terminal for more information.
Within freeCodeCamp Classroom, GitHub Codespaces is on par with Gitpod so that you can use either.
If you want a ready-made dev environment in your browser, make a fork of this repository and then prefix your fork with "gitpod.io/#". For example,
gitpod.io/#https://github.com/{your-github-user-name}/classroom
You will still need to setup your NextAuth-related environment variables in the .env file. For more information, please follow the "Setup Instructions" in the terminal. For setting up locally, follow the instructions below.
We recommend styling components using our design style guide.
We are strongly opinionated about adding new variables/tokens to the colors. After careful research, the colors have been chosen to respect the freeCodeCamp brand identity, developer experience, and accessibility.
This project uses a PostgreSQL database. You should follow the instructions in the linked documentation to set it up for your system. Alternatively, you can use the below commands for a docker-based setup on likes of Linux or macOS, if you have docker installed.
Docker based setup on Linux, macOS, etc.
# create a directory for the data
mkdir -p $HOME/docker/volumes/postgres
# start a container (this will use the "latest" tag. Use the version as needed)
docker run -it --name pgsql-classroom -e POSTGRES_PASSWORD=password -d --restart unless-stopped -p 5432:5432 -v $HOME/docker/volumes/postgres:/var/lib/postgresql/data postgres:latest
# change DATABASE_URL in your .env to
postgresql://postgres:password@localhost:5432/classroom
- Clone the project repository.
git clone https://github.com/freeCodeCamp/classroom.git cd classroom
- We use npm (specifically npm workspaces) to manage our dependencies.
npm ci
- Create
.env
file based on the.env.sample
file. Theses are the environment variables that are used by the application. - Run
npx prisma generate
. - Run
npx prisma db push
. - Run
npx prisma db seed
. - Run
npm run develop
. - Run
npm run mock-fcc-data
- Run
npx prisma studio
Need more help? Ran into issues? Check out this guide that walks you through all the steps of setting up the repository locally, without Docker.
Join us in our Discord Chat here.
Tips from CodeDay Labs Mentor @ngillux (Natalia Gill)
freeCodeCamp uses the following terms:
Certification = 'superblock'
Course (s) = 'blocks'
Everything under a course/block is a 'challenge'
Not sure if you already had this in your resources but I highly recommend this channel!
Try the steps in this discussion post (nvm install 16 and npm ci).
- Always make sure postgres is running 'sudo service postgresql start' to start
- Make sure PORTS 3001 & 3000 are public
- npm run develop
- npm run mock-fcc-data
- If you go to the classes page and see a blank page, you might need to change your user role in Prima to 'TEACHER'. To do this type npx prisma studio then click 'User' in prisma studio and update 'role a' under your user to be TEACHER and save
https://jestjs.io/docs/snapshot-testing
This tutorial/resource on testing a Next.js app with Jest is incredibly helpful, I recommend going through it to get comfortable using Jest with Next.js.
Following up with the above^ if you prefer video tutorials check this out. I recommend listening to his tidbit the first few seconds but the tutorial starts at 1:06. Important information specifically at the 5 minute mark. There is a blog post to complement this video tutorial. Keep in mind we use node package manager 'npm' and not yarn. Please let me know if any questions come up if you view this resource.
This is just a tip for all mentees working on any classroom issues; I think it’s important to try your best to understand core Next.js concepts, and take the time as you need. No need to rush. That’s the core of this project.
I wanted to share some starter blogs which can help you think of further concepts to explore in the documentation. So any concept you’re not too sure of you can type a search like :
Next.js data fetching
Next.js getServerSideProps
(Those above 2 topics I highly recommend reviewing)
Please check out these articles
https://dillionmegida.com/p/nextjs-main-concepts/
https://blog.devgenius.io/advanced-next-js-concepts-8439a8752597
Also the following terminology:
SSR - Server Side Rendering
SSG - Static Site Generation
ISR - Incremental Static Regeneration
CSR - Client Side Rendering
SSR is probably the focus point.
Also to follow up on the above, I don’t mean learn everything there is to know about Next.js, just the main concepts (and you can go in depth as needed). So depending on what your task is asking of you, you may want to focus on a specific Next.js concept that is present in your task (or knowledge of some concept that may be needed to complete the task).
Copyright © 2021 freeCodeCamp.org
The content of this repository is bound by the following licenses:
- The computer software is licensed under the BSD-3-Clause license.