๐Web Setup
๐ Introduction
Welcome to the AppFlowy Web project! This project aims to bring the powerful features of AppFlowy to the web. Whether you're a developer looking to contribute or a user eager to try out the latest features, this guide will help you get started.
AppFlowy Web is built with the following technologies:
React: A JavaScript library for building user interfaces.
TypeScript: A typed superset of JavaScript that compiles to plain JavaScript.
Bun: A fast all-in-one JavaScript runtime.
Nginx: A high-performance web server.
Docker: A platform to develop, ship, and run applications in containers.
Resource Sharing
To maintain consistency across different platforms, the Web project shares i18n translation files and Icons with the Flutter project. This ensures a unified user experience and reduces duplication of effort in maintaining these resources.
i18n Translation Files: The translation files are shared to provide a consistent localization experience across both Web and Flutter applications. The path to the translation files is
frontend/resources/translations/
.The translation files are stored in JSON format and contain translations for different languages. The files are named according to the language code (e.g.,
en.json
for English,es.json
for Spanish, etc.).
Let's dive in and get the project up and running! ๐
๐ Getting Started
Prerequisites
Before you begin, make sure you have the following installed on your system:
Node.js (v18.6.0) ๐ณ
pnpm (package manager) ๐ฆ
Jest (testing framework) ๐
Cypress (end-to-end testing) ๐งช
Clone the Repository
First, clone the repository to your local machine:
Install Dependencies
Install the required dependencies using pnpm:
Configure Environment Variables
Create a .env
file in the root of the project and add the following environment variables:
Start the Development Server
To start the development server, run the following command:
Usage
Access published views (currently we only support viewing web apps this way)
Create a
.env
file in the root of the project and add the following environment variables:
Install CORS Unblock extension in your browser to bypass CORS issues. Chrome
Open http://localhost:3000/854ea6c6-84cc-4710-9779-e704d058f92a/Databases-4443c9c8-1488-45b8-b48a-9ebb459672a2 to view the application in your browser.
you can replace the 854ea6c6-84cc-4710-9779-e704d058f92a
with the workspace id and Databases-4443c9c8-1488-45b8-b48a-9ebb459672a2
with the publish_name.
Note: if you use local server, you need to replace the
AF_WS_URL
,AF_BASE_URL
andAF_GOTRUE_URL
with your local server url in the.env
file. And make sure the server is running and you have published the view to your local server.
๐ Building for Production(Optional)
if you want to run the production build, use the following commands
This will start the application in development mode. Open http://localhost:3000 to view it in the browser.
๐งช Running Tests
Unit Tests
We use Jest for running unit tests. To run the tests, use the following command:
This will execute all the unit tests in the project and provide a summary of the results. โ
Components Tests
We use Cypress for end-to-end testing. To run the Cypress tests, use the following command:
This will open the Cypress Test Runner where you can run your end-to-end tests. ๐งช
Alternatively, to run Cypress tests in the headless mode, use:
Both commands will provide detailed test results and generate a code coverage report.
๐ Development Workflow
Linting
To maintain code quality, we use ESLint. To run the linter and fix any linting errors, use the following command:
๐ Production Deployment
Our production deployment process is automated using GitHub Actions. The process involves:
Setting up an AWS EC2 instance: We use an EC2 instance to host the application.
Installing Docker and Docker Compose: Docker is installed on the AWS instance.
Configuring SSH Access: SSH access is set up with a user and password.
Preparing Project Configuration: We configure
Dockerfile
,nginx.conf
, andserver.cjs
in the web project.Using GitHub Actions: We use the easingthemes/ssh-deploy@main action to deploy the project to the remote server.
The deployment steps include building the Docker image and running the Docker container with the necessary port mappings:
The Web server runs on Bun. For more details about Bun, please refer to the Bun documentation.
Last updated