An open API service indexing awesome lists of open source software.

https://github.com/albertarakelyan/learnfinity

πŸ“– A modern and user-friendly app for creating and sharing learning content only based on outer resources, found some great things on the internet then create an amazing Learning Path from them which will guarantee the desired skill.
https://github.com/albertarakelyan/learnfinity

educational-content educational-content-sharing learning learning-paths mongodb nodejs react web-application

Last synced: 2 months ago
JSON representation

πŸ“– A modern and user-friendly app for creating and sharing learning content only based on outer resources, found some great things on the internet then create an amazing Learning Path from them which will guarantee the desired skill.

Awesome Lists containing this project

README

        

# πŸ“– Learnfinity Plus

> A modern and user-friendly app for creating and sharing **Learning Paths** written in React/Typescript and Express/Nodejs.

![GitHub release (latest by date)](https://img.shields.io/github/v/release/AlbertArakelyan/learnfinity)
![Language](https://img.shields.io/badge/language-typescript%2C%20nodejs-blue)
![Platforms](https://img.shields.io/badge/platforms-Browser-green)
![License](https://img.shields.io/github/license/AlbertArakelyan/learnfinity)

![Screenshot](./screenshot.png)

**What is a Learning Path?**
A learning path is a structured guide that helps individuals achieve specific educational goals by organizing topics and resources in a logical sequence. It offers several benefits:

- Provides a clear roadmap for mastering a subject.
- Breaks down complex topics into manageable steps.
- Encourages consistent progress and self-paced learning.
- Facilitates skill development with tailored resources.

---

## πŸ“ About the project
A modern and user-friendly app for creating and sharing learning content only based on outer resources, find some great things on the internet then create an amazing Learning Path from them which will guarantee the desired skill.

## πŸ”‘ Key Features
- Works on **Browser**
- Databse in **the Cloud** for **Users**
- Public **Learning Path** creation
- Private **Learning Path** creation
- **Settings** and **Profile** pages
- **Dark Theme** 😊

## πŸ™ Donations
LearnfinityPlus is a free, open source software developed in my (little) spare time. If you liked the project and would like to support further development, please consider making a small donation, it really helps :)

Buy Me A Coffee

## πŸ‘¨β€πŸ’»Contibutors
People who helped the project along the way, thank you to all of you!

[![Image](https://contrib.rocks/image?repo=AlbertArakelyan/learnfinity)](https://github.com/AlbertArakelyan/learnfinity/graphs/contributors)

## 🏰 Architecture
### Backend
Standard adjusted [Node.js](https://nodejs.org/en) + [Express.js](https://expressjs.com/) architecture based on different best practices with very good expressed **Data Access Layer**. For the database I have used [MongoDB](https://www.mongodb.com/) with [Mongoose](https://mongoosejs.com/) ODM.

### Frontend
Standard [React](https://reactjs.org/) + [Redux](https://redux.js.org/) with [Typescript](https://www.typescriptlang.org/) usage. Has been used a modified **View-Container** architecture with special hooks providing all the business logic to the **Container** giving an advantage of not writing prop types and interfaces for each component but extend from the ReturnType of the hook.

### Tech Stack



Frontend
Backend






Typescript
React
Redux
Testing Library
Sass




Nodejs
Express
MongoDB
Mongoose



## πŸ“¦ Installation
_Note: make sure you have `.env` created from `.env.example` with appropriate variables._

_Note: Make sure you are using correct `node` and `yarn` versions._

### Versions
- node: `20.10.0`
- npm: `10.2.3`
- yarn: `1.22.21`

### Repo
- Clone the repo
```bash
git clone https://github.com/AlbertArakelyan/learnfinity.git
```

### Server
*in `server` directory*
- Install dependencies
```bash
yarn
```

- Start the server
```bash
yarn dev
```

The development server will start running at: `http://localhost:8000`

### Client
*in `client` directory*
- Install dependencies
```bash
yarn
```

- Start the client
```bash
yarn start
```

The development client will start running at: `http://localhost:3000`

[//]: # (## πŸš€ How to use)