2021-12-01 02:14:25 +00:00
|
|
|
// Copyright 2021 Signal Messenger, LLC
|
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
|
|
|
import * as log from '../../logging/log';
|
|
|
|
import { getHSL } from './color';
|
|
|
|
import { missingCaseError } from '../../util/missingCaseError';
|
|
|
|
|
|
|
|
export enum TextStyle {
|
|
|
|
Regular = 'Regular',
|
|
|
|
Highlight = 'Highlight',
|
|
|
|
Outline = 'Outline',
|
|
|
|
}
|
|
|
|
|
|
|
|
export function getTextStyleAttributes(
|
|
|
|
textStyle: TextStyle,
|
|
|
|
hueSliderValue: number
|
|
|
|
): {
|
|
|
|
fill: string;
|
|
|
|
stroke?: string;
|
|
|
|
strokeWidth: number;
|
|
|
|
textBackgroundColor: string;
|
|
|
|
} {
|
|
|
|
const color = getHSL(hueSliderValue);
|
|
|
|
switch (textStyle) {
|
|
|
|
case TextStyle.Regular:
|
|
|
|
return { fill: color, strokeWidth: 0, textBackgroundColor: '' };
|
|
|
|
case TextStyle.Highlight:
|
|
|
|
return {
|
2022-06-17 00:48:57 +00:00
|
|
|
fill: hueSliderValue >= 95 ? '#000' : '#fff',
|
2021-12-01 02:14:25 +00:00
|
|
|
strokeWidth: 0,
|
|
|
|
textBackgroundColor: color,
|
|
|
|
};
|
|
|
|
case TextStyle.Outline:
|
|
|
|
return {
|
2022-06-17 00:48:57 +00:00
|
|
|
fill: hueSliderValue >= 95 ? '#000' : '#fff',
|
2021-12-01 02:14:25 +00:00
|
|
|
stroke: color,
|
|
|
|
strokeWidth: 2,
|
|
|
|
textBackgroundColor: '',
|
|
|
|
};
|
|
|
|
default:
|
|
|
|
log.error(missingCaseError(textStyle));
|
|
|
|
return getTextStyleAttributes(TextStyle.Regular, hueSliderValue);
|
|
|
|
}
|
|
|
|
}
|