Skip to content

Latest commit

 

History

History
108 lines (74 loc) · 4.15 KB

README.md

File metadata and controls

108 lines (74 loc) · 4.15 KB

bg-13

React FilePad: File Explorer & Editor built with Clean Architecture Principles

This project showcases a File Explorer & Editor developed using React, adhering to the principles of clean architecture. By employing a layered code structure, the application becomes more manageable and facilitates effective testing. Leveraging Redux Toolkit for state management enhances performance and simplifies implementation. This example serves as a valuable reference for structuring React applications in accordance with Clean Architecture principles, empowering developers to build robust and scalable software solutions.

Features

  • Create New Folder and File
  • Monaco Editor Supported
  • Download File
  • Lexical Editor Supported
  • Excalidraw Whiteboard Supported
  • Download Folder
  • Export File to PDF
  • Export Folder to PDF
  • Open Local File
  • Open Local Folder

Authors

Tech Stack

  • ReactJS
  • Redux Toolkit
  • TypeScript
  • Sass
  • Ant Design

Environment Setup

  • Download and install Git
  • Download and install Node.js

Run Locally

Clone the project

  git clone https://github.com/jhasuraj01/filepad.git

Go to the project directory

  cd filepad

Install dependencies

  npm install

Start the server

  npm run start

Folder Structure

The directory structure of the project is organized according to the principles of clean architecture. The project is divided into four main layers:

Presentation Layer

This layer is responsible for rendering the user interface and handling user interactions. It consists of the presentation directory and its subdirectories.

Domain Layer

This layer contains the business logic of the application. It consists of the domain directory and its subdirectories.

Infrastructure Layer

This layer provides the implementation details for the abstractions defined in the domain layer. It consists of the infrastructure directory and its subdirectories.

Adapters Layer

This layer provides the interfaces between the application and external systems. It consists of the adapters directory and its subdirectories.

Screenshots

FilePad Editor

FilePad Editor

FilePad File Explorer

FilePad Explorer

Context Menu - Create New File

Context Menu - Create New File

Folder Context Menu

Folder Context Menu

File Context Menu

File Context Menu

FilePad Editor: Mobile View
Mobile View

References

Appendix

This project is an example of how to structure a React application following the Clean Architecture principles. By separating the code into different layers, it becomes easier to maintain and test the application. The use of Redux Toolkit simplifies the implementation of state management and improves the performance of the application.