summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/feature_flags/utils.js
blob: e77cb8406cc043d197c5eb87fcc7289566dce40b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
import { s__, n__, sprintf } from '~/locale';
import {
  ALL_ENVIRONMENTS_NAME,
  ROLLOUT_STRATEGY_ALL_USERS,
  ROLLOUT_STRATEGY_FLEXIBLE_ROLLOUT,
  ROLLOUT_STRATEGY_PERCENT_ROLLOUT,
  ROLLOUT_STRATEGY_USER_ID,
  ROLLOUT_STRATEGY_GITLAB_USER_LIST,
} from './constants';

const badgeTextByType = {
  [ROLLOUT_STRATEGY_ALL_USERS]: {
    name: s__('FeatureFlags|All Users'),
    parameters: null,
  },
  [ROLLOUT_STRATEGY_FLEXIBLE_ROLLOUT]: {
    name: s__('FeatureFlags|Percent rollout'),
    parameters: ({ parameters: { rollout, stickiness } }) => {
      switch (stickiness) {
        case 'USERID':
          return sprintf(s__('FeatureFlags|%{percent} by user ID'), { percent: `${rollout}%` });
        case 'SESSIONID':
          return sprintf(s__('FeatureFlags|%{percent} by session ID'), { percent: `${rollout}%` });
        case 'RANDOM':
          return sprintf(s__('FeatureFlags|%{percent} randomly'), { percent: `${rollout}%` });
        default:
          return sprintf(s__('FeatureFlags|%{percent} by available ID'), {
            percent: `${rollout}%`,
          });
      }
    },
  },
  [ROLLOUT_STRATEGY_PERCENT_ROLLOUT]: {
    name: s__('FeatureFlags|Percent of users'),
    parameters: ({ parameters: { percentage } }) => `${percentage}%`,
  },
  [ROLLOUT_STRATEGY_USER_ID]: {
    name: s__('FeatureFlags|User IDs'),
    parameters: ({ parameters: { userIds } }) =>
      sprintf(n__('FeatureFlags|%d user', 'FeatureFlags|%d users', userIds.split(',').length)),
  },
  [ROLLOUT_STRATEGY_GITLAB_USER_LIST]: {
    name: s__('FeatureFlags|User List'),
    parameters: ({ user_list: { name } }) => name,
  },
};

const scopeName = ({ environment_scope: scope }) =>
  scope === ALL_ENVIRONMENTS_NAME ? s__('FeatureFlags|All Environments') : scope;

export const labelForStrategy = (strategy) => {
  const { name, parameters } = badgeTextByType[strategy.name];

  if (parameters) {
    return sprintf('%{name} - %{parameters}: %{scopes}', {
      name,
      parameters: parameters(strategy),
      scopes: strategy.scopes.map(scopeName).join(', '),
    });
  }

  return sprintf('%{name}: %{scopes}', {
    name,
    scopes: strategy.scopes.map(scopeName).join(', '),
  });
};