// Copyright 2019-2021 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import { createSelector } from 'reselect'; import { isInteger } from 'lodash'; import { ITEM_NAME as UNIVERSAL_EXPIRE_TIMER_ITEM } from '../../util/universalExpireTimer'; import { StateType } from '../reducer'; import { ItemsStateType } from '../ducks/items'; import { ConversationColorType, CustomColorType, DEFAULT_CONVERSATION_COLOR, } from '../../types/Colors'; import { getPreferredReactionEmoji as getPreferredReactionEmojiFromStoredValue } from '../../reactions/preferredReactionEmoji'; const DEFAULT_PREFERRED_LEFT_PANE_WIDTH = 320; export const getItems = (state: StateType): ItemsStateType => state.items; export const getUserAgent = createSelector( getItems, (state: ItemsStateType): string => state.userAgent as string ); export const getPinnedConversationIds = createSelector( getItems, (state: ItemsStateType): Array => (state.pinnedConversationIds || []) as Array ); export const getUniversalExpireTimer = createSelector( getItems, (state: ItemsStateType): number => state[UNIVERSAL_EXPIRE_TIMER_ITEM] || 0 ); export const getDefaultConversationColor = createSelector( getItems, ( state: ItemsStateType ): { color: ConversationColorType; customColorData?: { id: string; value: CustomColorType; }; } => state.defaultConversationColor ?? DEFAULT_CONVERSATION_COLOR ); export const getCustomColors = createSelector( getItems, (state: ItemsStateType): Record | undefined => state.customColors?.colors ); export const getEmojiSkinTone = createSelector( getItems, ({ skinTone }: Readonly): number => typeof skinTone === 'number' && isInteger(skinTone) && skinTone >= 0 && skinTone <= 5 ? skinTone : 0 ); export const getPreferredLeftPaneWidth = createSelector( getItems, ({ preferredLeftPaneWidth }: Readonly): number => typeof preferredLeftPaneWidth === 'number' && Number.isInteger(preferredLeftPaneWidth) ? preferredLeftPaneWidth : DEFAULT_PREFERRED_LEFT_PANE_WIDTH ); export const getPreferredReactionEmoji = createSelector( getItems, getEmojiSkinTone, (state: Readonly, skinTone: number): Array => getPreferredReactionEmojiFromStoredValue( state.preferredReactionEmoji, skinTone ) );