diff options
| author | Henry Jameson <me@hjkos.com> | 2024-03-04 19:53:45 +0200 |
|---|---|---|
| committer | Henry Jameson <me@hjkos.com> | 2024-03-04 19:53:45 +0200 |
| commit | 7e01d2083d3e26d5239a332cf12e520468a39565 (patch) | |
| tree | 939597b0d9a9fdc6ed5a9694e79e208a03382e33 /src/services/theme_data | |
| parent | 075f2cb903fa45ea8e7a52098fd7091b0b14a9fd (diff) | |
proper selection colors
Diffstat (limited to 'src/services/theme_data')
| -rw-r--r-- | src/services/theme_data/theme3_slot_functions.js | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/src/services/theme_data/theme3_slot_functions.js b/src/services/theme_data/theme3_slot_functions.js index 2715c827..074a88f0 100644 --- a/src/services/theme_data/theme3_slot_functions.js +++ b/src/services/theme_data/theme3_slot_functions.js @@ -1,5 +1,5 @@ import { convert, brightness } from 'chromatism' -import { alphaBlend, relativeLuminance } from '../color_convert/color_convert.js' +import { alphaBlend, getTextColor, relativeLuminance } from '../color_convert/color_convert.js' export const process = (text, functions, { findColor, findShadow }, { dynamicVars, staticVars }) => { const { funcName, argsString } = /\$(?<funcName>\w+)\((?<argsString>[#a-zA-Z0-9-,.'"\s]*)\)/.exec(text).groups @@ -23,6 +23,17 @@ export const colorFunctions = { return { ...colorArg, a: amount } } }, + textColor: { + argsNeeded: 2, + exec: (args, { findColor }, { dynamicVars, staticVars }) => { + const [backgroundArg, foregroundArg, preserve = 'preserve'] = args + + const background = convert(findColor(backgroundArg, { dynamicVars, staticVars })).rgb + const foreground = convert(findColor(foregroundArg, { dynamicVars, staticVars })).rgb + + return getTextColor(background, foreground, preserve === 'preserve') + } + }, blend: { argsNeeded: 3, exec: (args, { findColor }, { dynamicVars, staticVars }) => { |
