signal-desktop/ts/util/migrateColor.ts

45 lines
1.2 KiB
TypeScript
Raw Normal View History

2023-01-03 19:55:46 +00:00
// Copyright 2018 Signal Messenger, LLC
2020-10-30 20:34:04 +00:00
// SPDX-License-Identifier: AGPL-3.0-only
2021-08-06 00:17:05 +00:00
import { sample } from 'lodash';
2024-03-15 14:20:33 +00:00
import { AVATAR_COLOR_COUNT, AvatarColors } from '../types/Colors';
import type { ConversationAttributesType } from '../model-types';
import type { AvatarColorType, CustomColorType } from '../types/Colors';
2024-03-15 14:20:33 +00:00
import type { ServiceIdString } from '../types/ServiceId';
2021-08-06 00:17:05 +00:00
const NEW_COLOR_NAMES = new Set(AvatarColors);
2024-03-15 14:20:33 +00:00
export function migrateColor(
serviceId?: ServiceIdString,
color?: string
): AvatarColorType {
2021-08-06 00:17:05 +00:00
if (color && NEW_COLOR_NAMES.has(color)) {
return color;
}
2021-08-06 00:17:05 +00:00
2024-03-15 14:20:33 +00:00
if (!serviceId) {
return sample(AvatarColors) || AvatarColors[0];
}
const index = (parseInt(serviceId.slice(-4), 16) || 0) % AVATAR_COLOR_COUNT;
2024-03-15 14:20:33 +00:00
return AvatarColors[index];
}
export function getCustomColorData(conversation: ConversationAttributesType): {
customColor?: CustomColorType;
customColorId?: string;
} {
if (conversation.conversationColor !== 'custom') {
return {
customColor: undefined,
customColorId: undefined,
};
}
return {
customColor: conversation.customColor,
customColorId: conversation.customColorId,
};
}