Skip to content

Latest commit

 

History

History
120 lines (88 loc) · 4.2 KB

Development.md

File metadata and controls

120 lines (88 loc) · 4.2 KB

Introduction

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!

Get Started

FeatBit consists of multiple services, to understand the architecture, please read our document.

Architecture

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.

Setup dependencies

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.

Run API

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.

Run UI

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

Internationalization

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.