signal-desktop/ts/state/selectors/user.ts

106 lines
2.7 KiB
TypeScript
Raw Normal View History

2022-01-26 17:05:26 -06:00
// Copyright 2019-2022 Signal Messenger, LLC
2020-10-30 15:34:04 -05:00
// SPDX-License-Identifier: AGPL-3.0-only
2019-01-14 13:49:58 -08:00
import { createSelector } from 'reselect';
import type { LocalizerType, ThemeType } from '../../types/Util';
2021-10-26 15:59:08 -07:00
import type { UUIDStringType } from '../../types/UUID';
import type { LocaleMessagesType } from '../../types/I18N';
import type { MenuOptionsType } from '../../types/menu';
2019-01-14 13:49:58 -08:00
import type { StateType } from '../reducer';
import type { UserStateType } from '../ducks/user';
2019-01-14 13:49:58 -08:00
2022-01-26 17:05:26 -06:00
import { isAlpha, isBeta } from '../../util/version';
2019-01-14 13:49:58 -08:00
export const getUser = (state: StateType): UserStateType => state.user;
export const getUserNumber = createSelector(
getUser,
(state: UserStateType): string | undefined => state.ourNumber
2019-01-14 13:49:58 -08:00
);
export const getUserDeviceId = createSelector(
getUser,
(state: UserStateType): number | undefined => state.ourDeviceId
);
2019-01-14 13:49:58 -08:00
export const getRegionCode = createSelector(
getUser,
(state: UserStateType): string | undefined => state.regionCode
2019-01-14 13:49:58 -08:00
);
export const getUserConversationId = createSelector(
getUser,
(state: UserStateType): string | undefined => state.ourConversationId
);
export const getUserUuid = createSelector(
getUser,
(state: UserStateType): UUIDStringType | undefined => state.ourUuid
);
2019-01-14 13:49:58 -08:00
export const getIntl = createSelector(
getUser,
(state: UserStateType): LocalizerType => state.i18n
);
export const getLocaleMessages = createSelector(
getUser,
(state: UserStateType): LocaleMessagesType => state.localeMessages
);
export const getInteractionMode = createSelector(
getUser,
(state: UserStateType) => state.interactionMode
);
export const getAttachmentsPath = createSelector(
getUser,
(state: UserStateType): string => state.attachmentsPath
);
export const getStickersPath = createSelector(
getUser,
(state: UserStateType): string => state.stickersPath
);
2019-11-07 13:36:16 -08:00
export const getPlatform = createSelector(
getUser,
(state: UserStateType): string => state.platform
);
export const getTempPath = createSelector(
getUser,
(state: UserStateType): string => state.tempPath
);
export const getTheme = createSelector(
getUser,
(state: UserStateType): ThemeType => state.theme
);
2022-01-26 17:05:26 -06:00
const getVersion = createSelector(
getUser,
(state: UserStateType) => state.version
);
export const getIsAlpha = createSelector(getVersion, isAlpha);
export const getIsBeta = createSelector(getVersion, isBeta);
export const getIsMainWindowMaximized = createSelector(
getUser,
(state: UserStateType): boolean => state.isMainWindowMaximized
);
export const getIsMainWindowFullScreen = createSelector(
getUser,
(state: UserStateType): boolean => state.isMainWindowFullScreen
);
export const getMenuOptions = createSelector(
getUser,
(state: UserStateType): MenuOptionsType => state.menuOptions
);