2021-11-19 16:45:10 +01:00
|
|
|
import type { ChatType } from './types'
|
2021-11-22 13:45:19 +01:00
|
|
|
const validateColor = require('validate-color').default
|
2021-11-19 16:45:10 +01:00
|
|
|
|
|
|
|
type AutoColorValue = string
|
|
|
|
|
|
|
|
interface AutoColors {
|
|
|
|
mainForeground: AutoColorValue
|
|
|
|
mainBackground: AutoColorValue
|
|
|
|
greyForeground: AutoColorValue
|
|
|
|
greyBackground: AutoColorValue
|
|
|
|
menuForeground: AutoColorValue
|
|
|
|
menuBackground: AutoColorValue
|
|
|
|
inputForeground: AutoColorValue
|
|
|
|
inputBackground: AutoColorValue
|
|
|
|
buttonForeground: AutoColorValue
|
|
|
|
buttonBackground: AutoColorValue
|
|
|
|
link: AutoColorValue
|
|
|
|
linkHover: AutoColorValue
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param chatType value of the settings 'chat-type'
|
|
|
|
* @param theme value of the settings 'converse-theme'
|
|
|
|
* @returns true if the theme can use autocolors
|
|
|
|
*/
|
|
|
|
function isAutoColorsAvailable (chatType: ChatType, theme: string): boolean {
|
|
|
|
if (chatType !== 'builtin-prosody' && chatType !== 'builtin-converse') {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return theme === 'peertube' // currently the only theme that can handle autocolors.
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param autocolors
|
|
|
|
* @returns true if ok. Else a string array with invalid values.
|
|
|
|
*/
|
|
|
|
function areAutoColorsValid (autocolors: AutoColors): true | string[] {
|
|
|
|
const errors: string[] = []
|
|
|
|
for (const k in autocolors) {
|
|
|
|
const color = autocolors[k as keyof AutoColors]
|
2021-11-22 13:45:19 +01:00
|
|
|
if (!validateColor(color)) {
|
2021-11-19 16:45:10 +01:00
|
|
|
errors.push(color)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (errors.length) {
|
|
|
|
return errors
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
export {
|
|
|
|
AutoColors,
|
|
|
|
isAutoColorsAvailable,
|
|
|
|
areAutoColorsValid
|
|
|
|
}
|