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.
- Host: GitHub
- URL: https://github.com/albertarakelyan/learnfinity
- Owner: AlbertArakelyan
- License: gpl-3.0
- Created: 2024-01-06T13:20:26.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-10-07T08:47:42.000Z (8 months ago)
- Last Synced: 2024-10-12T08:12:41.058Z (7 months ago)
- Topics: educational-content, educational-content-sharing, learning, learning-paths, mongodb, nodejs, react, web-application
- Language: TypeScript
- Homepage: https://learnfinityplus.com
- Size: 5.1 MB
- Stars: 6
- Watchers: 1
- Forks: 0
- Open Issues: 20
-
Metadata Files:
- Readme: README.md
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.




**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 :)## π¨βπ»Contibutors
People who helped the project along the way, thank you to all of you](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
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
## π¦ 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)