From f0bbb75df50eb7df91cbb172f2b1ff4a5a4d5310 Mon Sep 17 00:00:00 2001 From: Henry Jameson Date: Mon, 19 Feb 2024 00:00:43 +0200 Subject: [PATCH] properly sort, properly do icon colors, some initial attachment buttons work --- src/components/attachment.style.js | 23 +++++++++++++ src/components/button_unstyled.style.js | 2 ++ src/components/icon.style.js | 2 +- .../theme_data/theme_data_3.service.js | 33 +++++++++++++------ 4 files changed, 49 insertions(+), 11 deletions(-) create mode 100644 src/components/attachment.style.js diff --git a/src/components/attachment.style.js b/src/components/attachment.style.js new file mode 100644 index 00000000..b6c5da6e --- /dev/null +++ b/src/components/attachment.style.js @@ -0,0 +1,23 @@ +export default { + name: 'Attachment', + selector: '.Attachment', + validInnerComponents: [ + 'Border', + 'ButtonUnstyled' + ], + defaultRules: [ + { + directives: { + roundness: 3 + } + }, + { + component: 'ButtonUnstyled', + parent: { component: 'Attachment' }, + directives: { + background: '#FFFFFF', + opacity: 0.9 + } + } + ] +} diff --git a/src/components/button_unstyled.style.js b/src/components/button_unstyled.style.js index 89e8499c..60dd0d47 100644 --- a/src/components/button_unstyled.style.js +++ b/src/components/button_unstyled.style.js @@ -16,6 +16,8 @@ export default { defaultRules: [ { directives: { + background: '#ffffff', + opacity: 0, shadow: [] } }, diff --git a/src/components/icon.style.js b/src/components/icon.style.js index 81bbbce0..6cb9e4e3 100644 --- a/src/components/icon.style.js +++ b/src/components/icon.style.js @@ -6,7 +6,7 @@ export default { { component: 'Icon', directives: { - textColor: '$blend(--parent, 0.5, --parent--text)', + textColor: '$blend(--stack, 0.5, --parent--text)', textAuto: 'no-auto' } } diff --git a/src/services/theme_data/theme_data_3.service.js b/src/services/theme_data/theme_data_3.service.js index c301d148..84ff20b2 100644 --- a/src/services/theme_data/theme_data_3.service.js +++ b/src/services/theme_data/theme_data_3.service.js @@ -16,7 +16,8 @@ const components = { FunText: null, Link: null, Icon: null, - Border: null + Border: null, + Panel: null } // Loading all style.js[on] files dynamically @@ -175,10 +176,14 @@ export const init = (extraRuleset, palette) => { const parentsA = unroll(a).length const parentsB = unroll(b).length - if (parentsA === parentsB || (parentsB !== 0 && parentsA !== 0)) return ai - bi + if (parentsA === parentsB) { + if (a.component === 'Text') return -1 + if (b.component === 'Text') return 1 + return ai - bi + } if (parentsA === 0 && parentsB !== 0) return -1 if (parentsB === 0 && parentsA !== 0) return 1 - return 0 // failsafe, shouldn't happen? + return parentsA - parentsB }) .map(({ data }) => data) @@ -190,7 +195,12 @@ export const init = (extraRuleset, palette) => { if (color.startsWith('--')) { const [variable, modifier] = color.split(/,/g).map(str => str.trim()) const variableSlot = variable.substring(2) - if (variableSlot.startsWith('parent')) { + if (variableSlot === 'stack') { + console.log(dynamicVars) + console.log(stacked) + const { r, g, b } = dynamicVars.stacked + targetColor = { r, g, b } + } else if (variableSlot.startsWith('parent')) { if (variableSlot === 'parent') { const { r, g, b } = dynamicVars.lowerLevelBackground targetColor = { r, g, b } @@ -451,6 +461,7 @@ export const init = (extraRuleset, palette) => { } dynamicVars.inheritedBackground = lowerLevelBackground + dynamicVars.stacked = convert(stacked[lowerLevelSelector]).rgb const intendedTextColor = convert(findColor(inheritedTextColor, dynamicVars)).rgb const textColor = newTextRule.directives.textAuto === 'no-auto' @@ -500,7 +511,7 @@ export const init = (extraRuleset, palette) => { let addRuleNeeded = false // TODO: DEFAULT TEXT COLOR - const lowerLevelComputedBackground = computed[lowerLevelSelector]?.background || convert('#FFFFFF').rgb + const lowerLevelStackedBackground = stacked[lowerLevelSelector] || convert('#FF00FF').rgb if (computedDirectives.shadow != null || computedDirectives.roundness != null) { addRuleNeeded = true @@ -532,11 +543,12 @@ export const init = (extraRuleset, palette) => { if (alpha >= 1) { blend = rgb } else if (alpha <= 0) { - blend = lowerLevelComputedBackground + blend = lowerLevelStackedBackground } else { - blend = alphaBlend(rgb, computedDirectives.opacity, lowerLevelComputedBackground) + blend = alphaBlend(rgb, computedDirectives.opacity, lowerLevelStackedBackground) } stacked[selector] = blend + dynamicVars.stacked = blend computed[selector].background = { ...rgb, a: computedDirectives.opacity ?? 1 } } } @@ -544,11 +556,12 @@ export const init = (extraRuleset, palette) => { if (!stacked[selector]) { computedDirectives.background = 'transparent' computedDirectives.opacity = 0 - stacked[selector] = lowerLevelComputedBackground - computed[selector].background = { ...lowerLevelComputedBackground, a: 0 } + stacked[selector] = lowerLevelStackedBackground + computed[selector].background = { ...lowerLevelStackedBackground, a: 0 } } - computed[selector].dynamicVars.background = computed[selector].background + dynamicVars.stacked = lowerLevelStackedBackground + dynamicVars.background = computed[selector].background if (addRuleNeeded) { addRule({