Learn programming and computer science for free.
This website is a platform to learn to code. It is inspired by sites like freeCodeCamp and CSS Tricks. coffeeclass.io is open source and we encourage contributions to both the website itself and the content! Read on to learn more about the project.
- Clone this repo:
git clone https://github.com/carlson-technologies/coffeeclass.io.git
- Move into root (where this file is) and run
yarn
- (Optional) Create a
.env
file and copy into it the content of.env.example
. It will run without these. - Run
yarn dev
to start the server - Navigate to http://localhost:3000
If you are creating a PR, create a new branch. Before you commit run yarn build
. This will run the tests and make sure everything is working.
Note: If you are not planning on making a PR, you can run rm -rf .git
to remove git tracking.
- ๐ Next.js - Framework
- ๐จ Chakra UI - CSS Component Library
- ๐ TypeScript (and some JavaScript) - Web language of choice
- ๐งช Jest - Testing
- โ๐ผ MDX - Database for Article, Authors, Courses, Tags
- ๐บ Vercel - Deployment
- ๐ป GitHub - Version Control
- ๐ Google Analytics - Analytics
- ๐ Splitbee - More Analytics
- ๐ Algolia - Search
Besides the above, this site uses additional yarn packages and some other smaller external software.
This repo is broken up into 4 main parts.
src
: This is the Next.js website.content
: This is the content for the website stored inmdx
files.public
: This is the static assets for the website.tests
: Jest unit tests for the website.
Inside the src
folder, we have the following:
components
: Our UI components.configs
: Various configuration files for courses.pages
: Where the pages (routes) and api routes are stored.scripts
: Stand alone scripts (DRY) and build scriptsstyles
: Theme styles and Chakra UI default theme config.
This entire project is open source. We encourage contributions! Read on to see how you can contribute.
If you want to contribute an article please follow the steps on https://www.coffeeclass.io/contribute/getting-started/
You can also contribute to the website itself. New features and bug fixes are always appreciated. Feel free to check out the Roadmap ๐ for future plans and what we're working on currently. If you see anything you want to tackle, feel free to leave a comment on the Roadmap user story and open a PR!
Our roadmap is also our agile development process. View cards, see what we are working on, view future plans and more on the roadmap.