diff options
Diffstat (limited to 'server/sonar-web/src/main/js/apps/settings/store/values.ts')
-rw-r--r-- | server/sonar-web/src/main/js/apps/settings/store/values.ts | 78 |
1 files changed, 0 insertions, 78 deletions
diff --git a/server/sonar-web/src/main/js/apps/settings/store/values.ts b/server/sonar-web/src/main/js/apps/settings/store/values.ts deleted file mode 100644 index 478a873c02d..00000000000 --- a/server/sonar-web/src/main/js/apps/settings/store/values.ts +++ /dev/null @@ -1,78 +0,0 @@ -/* - * SonarQube - * Copyright (C) 2009-2022 SonarSource SA - * mailto:info AT sonarsource DOT com - * - * This program is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 3 of the License, or (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public License - * along with this program; if not, write to the Free Software Foundation, - * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. - */ -import { keyBy, omit } from 'lodash'; -import { combineReducers } from 'redux'; -import { ActionType } from '../../../store/utils/actions'; -import { SettingValue } from '../../../types/settings'; -import { Dict } from '../../../types/types'; - -enum Actions { - receiveValues = 'RECEIVE_VALUES' -} - -type Action = ActionType<typeof receiveValues, Actions.receiveValues>; - -type SettingsState = Dict<SettingValue>; - -export interface State { - components: Dict<SettingsState>; - global: SettingsState; -} - -export function receiveValues( - updateKeys: string[], - settings: Array<{ key: string; value?: string }>, - component?: string -) { - return { type: Actions.receiveValues, updateKeys, settings, component }; -} - -function components(state: State['components'] = {}, action: Action) { - const { component: key } = action; - if (!key) { - return state; - } - if (action.type === Actions.receiveValues) { - const settingsByKey = keyBy(action.settings, 'key'); - return { ...state, [key]: { ...omit(state[key] || {}, action.updateKeys), ...settingsByKey } }; - } - return state; -} - -function global(state: State['components'] = {}, action: Action) { - if (action.type === Actions.receiveValues) { - if (action.component) { - return state; - } - const settingsByKey = keyBy(action.settings, 'key'); - return { ...omit(state, action.updateKeys), ...settingsByKey }; - } - - return state; -} - -export default combineReducers({ components, global }); - -export function getValue(state: State, key: string, component?: string): SettingValue | undefined { - if (component) { - return state.components[component] && state.components[component][key]; - } - return state.global[key]; -} |