Welcome to the FeatBit development documentation.
This document will guide you through the stages of setting up your development environment, connecting to our code base and finally submitting code to the project!
FeatBit consists of multiple services, to understand the architecture, please read our document.
To get started, we need to clone FeatBit's repository first.
git clone https://github.com/featbit/featbit
Most of the contribution work will focus on UI and API, we just need to set up their dependencies via docker compose and launch these two services from the code.
Open docker-compose-dev.yml and comment out ui and/or api-server service according to the scope of your work, they are the first two services. Then do
docker compose -f docker-compose-dev.yml up -d
Wait until all services are successfully launched, and we're ready to run API and/or UI locally.
The API project is built with .NET 6, make sure you have the latest .NET 6.0 SDK installed before you start.
The API solution is located at modules/back-end folder. To connect to its dependencies(mongodb, kafka, da-server), we need to update the src/Api/appsettings.Development.json file to this:
{
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft.AspNetCore": "Warning"
}
},
"Jwt": {
"Issuer": "featbit",
"Audience": "featbit-api",
"Key": "featbit-identity-key"
},
"MongoDb": {
"ConnectionString": "mongodb://admin:password@localhost:27017",
"Database": "featbit"
},
"Kafka": {
"BootstrapServers": "localhost:29092"
},
"OLAP": {
"ServiceHost": "http://localhost:8200"
},
"AllowedHosts": "*"
}
Navigate to modules/back-end/src/Api folder and run dotnet run
, then the swagger would be available
at http://localhost:5000/swagger.
The UI is built with Angular and NG-ZORRO, please refer to their docs for more details.
Navigate to modules/front-end folder and do the following commands:
npm install
npm run start
The UI would be available at http://localhost:4200.
The above process would launch the UI in English language.
As ng serve only supports one single locale, during development, the locale-switcher component doesn't work. If you want to check a different language, run the app with one of the following
npm run start // English, available at localhost:4200
npm run start:zh // Chinese, available at localhost:4201
FeatBit should be available to everyone everywhere, and we don't want language to be a barrier. So for this reason we have implemented internationalization features into our codebase.
FeatBit UI uses offical @angular/localize package to implement the i18n, please read the official doc for how to use it. The language resource files are under * modules/front-end/src/locale* folder, with following format messages.xx.xlf, xx is the language code.
Currently only English and Chinese are available, we would be very grateful to have contributors for other languages too.
If you put a text in the UI, at the end of the developing work, you need to put its translations into the corresponding resource file. This work could be very tedius, we created a library to faciliate the job, you need to run the command
npm run i18n
English would be generated automatically in messages.xlf, you just need to put the translations into message.xx.xlf. A
small trick is to search this text <target></target>
in the file and put the translation between target tag.