Merge branch 'fix-broken-themes' into 'develop'

Fix broken themes

Closes #1330

See merge request pleroma/pleroma-fe!1925
This commit is contained in:
HJ 2024-07-25 16:39:19 +00:00
commit 23657e88ec
2 changed files with 29 additions and 16 deletions

View file

@ -0,0 +1 @@
fixed themes for spw and kazvmoew

View file

@ -237,11 +237,11 @@ const interfaceMod = {
} else if (themeName) { } else if (themeName) {
promise = getPreset(themeName).then(themeData => normalizeThemeData(themeData)) promise = getPreset(themeName).then(themeData => normalizeThemeData(themeData))
} else if (userThemeSource || userThemeSnapshot) { } else if (userThemeSource || userThemeSnapshot) {
if (userThemeSource && userThemeSource.themeEngineVersion === CURRENT_VERSION) { promise = Promise.resolve(normalizeThemeData({
promise = Promise.resolve(normalizeThemeData(userThemeSource)) _pleroma_theme_version: 2,
} else { theme: userThemeSnapshot,
promise = Promise.resolve(normalizeThemeData(userThemeSnapshot)) source: userThemeSource
} }))
} else if (actualThemeName && actualThemeName !== 'custom') { } else if (actualThemeName && actualThemeName !== 'custom') {
promise = getPreset(actualThemeName).then(themeData => { promise = getPreset(actualThemeName).then(themeData => {
const realThemeData = normalizeThemeData(themeData) const realThemeData = normalizeThemeData(themeData)
@ -355,10 +355,8 @@ const interfaceMod = {
export default interfaceMod export default interfaceMod
export const normalizeThemeData = (input) => { export const normalizeThemeData = (input) => {
let themeData = input if (Array.isArray(input)) {
const themeData = { colors: {} }
if (Array.isArray(themeData)) {
themeData = { colors: {} }
themeData.colors.bg = input[1] themeData.colors.bg = input[1]
themeData.colors.fg = input[2] themeData.colors.fg = input[2]
themeData.colors.text = input[3] themeData.colors.text = input[3]
@ -370,18 +368,32 @@ export const normalizeThemeData = (input) => {
return generatePreset(themeData).theme return generatePreset(themeData).theme
} }
if (themeData.themeFileVerison === 1) { let themeData, themeSource
return generatePreset(themeData).theme
}
if (input.themeFileVerison === 1) {
// this might not be even used at all, some leftover of unimplemented code in V2 editor
return generatePreset(input).theme
} else if (
Object.prototype.hasOwnProperty.call(input, '_pleroma_theme_version') ||
Object.prototype.hasOwnProperty.call(input, 'source') ||
Object.prototype.hasOwnProperty.call(input, 'theme')
) {
// We got passed a full theme file
themeData = input.theme
themeSource = input.source
} else if (Object.prototype.hasOwnProperty.call(input, 'themeEngineVersion')) {
// We got passed a source/snapshot
themeData = input
themeSource = input
}
// New theme presets don't have 'theme' property, they use 'source' // New theme presets don't have 'theme' property, they use 'source'
const themeSource = themeData.source
let out // shout, shout let it all out let out // shout, shout let it all out
if (!themeData.theme || (themeSource && themeSource.themeEngineVersion === CURRENT_VERSION)) { if (themeSource && themeSource.themeEngineVersion === CURRENT_VERSION) {
out = themeSource || themeData // There are some themes in wild that have completely broken source
out = { ...(themeData || {}), ...themeSource }
} else { } else {
out = themeData.theme out = themeData
} }
// generatePreset here basically creates/updates "snapshot", // generatePreset here basically creates/updates "snapshot",