Add theme selection dropdown and refactor theme handling
Introduce a DxComboBox in MainLayout for selecting between multiple themes. Update ThemeState to manage the current theme, provide a list of available themes, and apply the selected theme via a new SetTheme method. Refactor dark mode handling to work with the new theme system, and ensure UI updates on theme or mode changes.
This commit is contained in:
@@ -9,7 +9,12 @@
|
||||
|
||||
<main>
|
||||
<div class="top-row px-4">
|
||||
<DxButton Text="@(ThemeState.IsDarkMode ? "Dark Mode aus" : "Dark Mode an")" Click="ToggleTheme" />
|
||||
<DxComboBox Data="@ThemeState.AvailableThemes"
|
||||
Value="@ThemeState.CurrentThemeName"
|
||||
ValueChanged="@((string t) => ThemeState.SetTheme(t))"
|
||||
style="width: 130px;" />
|
||||
<DxButton Text="@(ThemeState.IsDarkMode ? "Dark Mode aus" : "Dark Mode an")"
|
||||
Click="ToggleTheme" />
|
||||
<a href="https://learn.microsoft.com/aspnet/core/" target="_blank">About</a>
|
||||
</div>
|
||||
|
||||
|
||||
@@ -12,24 +12,46 @@ public class ThemeState
|
||||
}
|
||||
|
||||
public bool IsDarkMode { get; private set; }
|
||||
public string CurrentThemeName { get; private set; } = "Fluent";
|
||||
|
||||
public static readonly List<string> AvailableThemes = ["Fluent", "BlazingBerry", "Purple", "OfficeWhite", "BootstrapExternal"];
|
||||
|
||||
public event Action? OnChange;
|
||||
|
||||
public void SetDarkMode(bool isDarkMode)
|
||||
public void SetTheme(string themeName)
|
||||
{
|
||||
if (IsDarkMode == isDarkMode)
|
||||
{
|
||||
return;
|
||||
if (CurrentThemeName == themeName) return;
|
||||
CurrentThemeName = themeName;
|
||||
ApplyTheme();
|
||||
OnChange?.Invoke();
|
||||
}
|
||||
|
||||
public void SetDarkMode(bool isDarkMode)
|
||||
{
|
||||
if (IsDarkMode == isDarkMode) return;
|
||||
IsDarkMode = isDarkMode;
|
||||
ApplyTheme();
|
||||
OnChange?.Invoke();
|
||||
}
|
||||
|
||||
private void ApplyTheme()
|
||||
{
|
||||
if (CurrentThemeName == "Fluent")
|
||||
{
|
||||
var theme = Themes.Fluent.Clone(properties =>
|
||||
{
|
||||
properties.Mode = isDarkMode ? ThemeMode.Dark : ThemeMode.Light;
|
||||
properties.Mode = IsDarkMode ? ThemeMode.Dark : ThemeMode.Light;
|
||||
properties.ApplyToPageElements = true;
|
||||
});
|
||||
|
||||
themeChangeService.SetTheme(theme);
|
||||
}
|
||||
else if (CurrentThemeName == "BlazingBerry") themeChangeService.SetTheme(Themes.BlazingBerry);
|
||||
else if (CurrentThemeName == "Purple") themeChangeService.SetTheme(Themes.Purple);
|
||||
else if (CurrentThemeName == "OfficeWhite") themeChangeService.SetTheme(Themes.OfficeWhite);
|
||||
else if (CurrentThemeName == "BootstrapExternal") themeChangeService.SetTheme(Themes.BootstrapExternal);
|
||||
else
|
||||
themeChangeService.SetTheme(Themes.Fluent);
|
||||
|
||||
OnChange?.Invoke();
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user