Files
gerrit/polygerrit-ui/app/services
Tao Zhou d90e7f4e18 Add charset meta tag to all test files
This should prevent encoding issues when run tests
in different browsers individually

Change-Id: Iccc90619b5afda520a4160c930d2a50d90c3f7ed
2020-04-29 17:07:14 +02:00
..
2020-04-21 09:57:12 +02:00
2020-04-21 09:57:12 +02:00
2020-04-21 09:57:12 +02:00
2020-04-21 09:57:12 +02:00

What is services folder

'services' folder contains services used across multiple components.

What should be considered as services in Gerrit UI

Services should be stateful, if its just pure functions, consider having them in 'utils' instead.

Regarding all stateful should be considered as services or not, it's still TBD. Will update as soon as it's finalized.

How to access service

We use AppContext to access instance of service. It helps in mocking service in tests as well. We prefer setting instance of service in constructor and then accessing it from variable. We also allow access straight from appContext especially in static methods.

import {appContext} from '../../../services/app-context.js';

class T {
  constructor() {
    super();
    this.flagsService = appContext.flagsService;
  }

  action1() {
    if (this.flagsService.isEnabled('test)) {
      // do something
    }
  }
}

staticMethod() {
  if (appContext.flagsService.isEnabled('test)) {
    // do something
  }
}

What services we have

Flags

'flags' is a service to provide easy access to all enabled experiments.

import {appContext} from '../../../services/app-context.js';

// check if an experiment is enabled or not
if (appContext.flagsService.isEnabled('test')) {
  // do something
}