Merge pull request #168 from Tiktack/language-time-page
Language & Time page
This commit is contained in:
@@ -20,6 +20,7 @@
|
|||||||
MessageListPage,
|
MessageListPage,
|
||||||
MailListPage,
|
MailListPage,
|
||||||
ReadingPanePage,
|
ReadingPanePage,
|
||||||
SettingOptionsPage
|
LanguageTimePage,
|
||||||
|
SettingOptionsPage,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -377,6 +377,8 @@
|
|||||||
"SettingsHoverActions_Title": "Hover Actions",
|
"SettingsHoverActions_Title": "Hover Actions",
|
||||||
"SettingsLanguage_Description": "Change display language for Wino.",
|
"SettingsLanguage_Description": "Change display language for Wino.",
|
||||||
"SettingsLanguage_Title": "Display Language",
|
"SettingsLanguage_Title": "Display Language",
|
||||||
|
"SettingsLanguageTime_Title": "Language & Time",
|
||||||
|
"SettingsLanguageTime_Description": "Wino display language, preferred time format.",
|
||||||
"CategoriesFolderNameOverride": "Categories",
|
"CategoriesFolderNameOverride": "Categories",
|
||||||
"MoreFolderNameOverride": "More",
|
"MoreFolderNameOverride": "More",
|
||||||
"SettingsOptions_Title": "Settings",
|
"SettingsOptions_Title": "Settings",
|
||||||
|
|||||||
505
Wino.Core.Domain/Translator.Designer.cs
generated
505
Wino.Core.Domain/Translator.Designer.cs
generated
File diff suppressed because it is too large
Load Diff
49
Wino.Mail.ViewModels/LanguageTimePageViewModel.cs
Normal file
49
Wino.Mail.ViewModels/LanguageTimePageViewModel.cs
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
using System.Collections.Generic;
|
||||||
|
using System.ComponentModel;
|
||||||
|
using System.Linq;
|
||||||
|
using CommunityToolkit.Mvvm.ComponentModel;
|
||||||
|
using Wino.Core.Domain.Interfaces;
|
||||||
|
using Wino.Core.Domain.Models.Navigation;
|
||||||
|
using Wino.Core.Domain.Models.Translations;
|
||||||
|
|
||||||
|
namespace Wino.Mail.ViewModels
|
||||||
|
{
|
||||||
|
public partial class LanguageTimePageViewModel(IDialogService dialogService,
|
||||||
|
IPreferencesService preferencesService,
|
||||||
|
ITranslationService translationService) : BaseViewModel(dialogService)
|
||||||
|
{
|
||||||
|
public IPreferencesService PreferencesService { get; } = preferencesService;
|
||||||
|
private readonly ITranslationService _translationService = translationService;
|
||||||
|
|
||||||
|
[ObservableProperty]
|
||||||
|
private List<AppLanguageModel> _availableLanguages;
|
||||||
|
|
||||||
|
[ObservableProperty]
|
||||||
|
private AppLanguageModel _selectedLanguage;
|
||||||
|
|
||||||
|
private bool isInitialized = false;
|
||||||
|
|
||||||
|
public override void OnNavigatedTo(NavigationMode mode, object parameters)
|
||||||
|
{
|
||||||
|
base.OnNavigatedTo(mode, parameters);
|
||||||
|
|
||||||
|
AvailableLanguages = _translationService.GetAvailableLanguages();
|
||||||
|
|
||||||
|
SelectedLanguage = AvailableLanguages.FirstOrDefault(a => a.Language == PreferencesService.CurrentLanguage);
|
||||||
|
|
||||||
|
isInitialized = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override async void OnPropertyChanged(PropertyChangedEventArgs e)
|
||||||
|
{
|
||||||
|
base.OnPropertyChanged(e);
|
||||||
|
|
||||||
|
if (!isInitialized) return;
|
||||||
|
|
||||||
|
if (e.PropertyName == nameof(SelectedLanguage))
|
||||||
|
{
|
||||||
|
await _translationService.InitializeLanguageAsync(SelectedLanguage.Language);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,37 +1,17 @@
|
|||||||
using System.Collections.Generic;
|
using System;
|
||||||
using System.ComponentModel;
|
|
||||||
using System.Linq;
|
|
||||||
using CommunityToolkit.Mvvm.ComponentModel;
|
|
||||||
using CommunityToolkit.Mvvm.Input;
|
using CommunityToolkit.Mvvm.Input;
|
||||||
using CommunityToolkit.Mvvm.Messaging;
|
using CommunityToolkit.Mvvm.Messaging;
|
||||||
|
using Wino.Core.Domain;
|
||||||
using Wino.Core.Domain.Enums;
|
using Wino.Core.Domain.Enums;
|
||||||
using Wino.Core.Domain.Interfaces;
|
using Wino.Core.Domain.Interfaces;
|
||||||
using Wino.Core.Domain.Models.Navigation;
|
using Wino.Core.Domain.Models.Navigation;
|
||||||
using Wino.Core.Domain.Models.Translations;
|
|
||||||
using Wino.Core.Messages.Navigation;
|
using Wino.Core.Messages.Navigation;
|
||||||
|
|
||||||
namespace Wino.Mail.ViewModels
|
namespace Wino.Mail.ViewModels
|
||||||
{
|
{
|
||||||
public partial class SettingOptionsPageViewModel : BaseViewModel
|
public partial class SettingOptionsPageViewModel : BaseViewModel
|
||||||
{
|
{
|
||||||
private readonly ITranslationService _translationService;
|
public SettingOptionsPageViewModel(IDialogService dialogService) : base(dialogService) { }
|
||||||
private readonly IPreferencesService _preferencesService;
|
|
||||||
|
|
||||||
[ObservableProperty]
|
|
||||||
private List<AppLanguageModel> _availableLanguages;
|
|
||||||
|
|
||||||
[ObservableProperty]
|
|
||||||
private AppLanguageModel _selectedLanguage;
|
|
||||||
|
|
||||||
private bool isInitialized = false;
|
|
||||||
|
|
||||||
public SettingOptionsPageViewModel(IDialogService dialogService,
|
|
||||||
ITranslationService translationService,
|
|
||||||
IPreferencesService preferencesService) : base(dialogService)
|
|
||||||
{
|
|
||||||
_translationService = translationService;
|
|
||||||
_preferencesService = preferencesService;
|
|
||||||
}
|
|
||||||
|
|
||||||
[RelayCommand]
|
[RelayCommand]
|
||||||
private void GoAccountSettings() => Messenger.Send<NavigateSettingsRequested>();
|
private void GoAccountSettings() => Messenger.Send<NavigateSettingsRequested>();
|
||||||
@@ -39,44 +19,22 @@ namespace Wino.Mail.ViewModels
|
|||||||
public override void OnNavigatedTo(NavigationMode mode, object parameters)
|
public override void OnNavigatedTo(NavigationMode mode, object parameters)
|
||||||
{
|
{
|
||||||
base.OnNavigatedTo(mode, parameters);
|
base.OnNavigatedTo(mode, parameters);
|
||||||
|
|
||||||
AvailableLanguages = _translationService.GetAvailableLanguages();
|
|
||||||
|
|
||||||
SelectedLanguage = AvailableLanguages.FirstOrDefault(a => a.Language == _preferencesService.CurrentLanguage);
|
|
||||||
|
|
||||||
isInitialized = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override async void OnPropertyChanged(PropertyChangedEventArgs e)
|
|
||||||
{
|
|
||||||
base.OnPropertyChanged(e);
|
|
||||||
|
|
||||||
if (!isInitialized) return;
|
|
||||||
|
|
||||||
if (e.PropertyName == nameof(SelectedLanguage))
|
|
||||||
{
|
|
||||||
await _translationService.InitializeLanguageAsync(SelectedLanguage.Language);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
[RelayCommand]
|
[RelayCommand]
|
||||||
public void NavigateSubDetail(object type)
|
public void NavigateSubDetail(object type)
|
||||||
{
|
{
|
||||||
if (type is string stringParameter)
|
if (type is WinoPage pageType)
|
||||||
{
|
{
|
||||||
WinoPage pageType = default;
|
string pageTitle = pageType switch
|
||||||
|
{
|
||||||
string pageTitle = stringParameter;
|
WinoPage.PersonalizationPage => Translator.SettingsPersonalization_Title,
|
||||||
|
WinoPage.AboutPage => Translator.SettingsAbout_Title,
|
||||||
// They are just params and don't have to be localized. Don't change.
|
WinoPage.MessageListPage => Translator.SettingsMessageList_Title,
|
||||||
if (stringParameter == "Personalization")
|
WinoPage.ReadingPanePage => Translator.SettingsReadingPane_Title,
|
||||||
pageType = WinoPage.PersonalizationPage;
|
WinoPage.LanguageTimePage => Translator.SettingsLanguageTime_Title,
|
||||||
else if (stringParameter == "About")
|
_ => throw new NotImplementedException()
|
||||||
pageType = WinoPage.AboutPage;
|
};
|
||||||
else if (stringParameter == "Message List")
|
|
||||||
pageType = WinoPage.MessageListPage;
|
|
||||||
else if (stringParameter == "Reading Pane")
|
|
||||||
pageType = WinoPage.ReadingPanePage;
|
|
||||||
|
|
||||||
Messenger.Send(new BreadcrumbNavigationRequested(pageTitle, pageType));
|
Messenger.Send(new BreadcrumbNavigationRequested(pageTitle, pageType));
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -113,7 +113,6 @@ namespace Wino
|
|||||||
{
|
{
|
||||||
services.AddSingleton<IApplicationResourceManager<ResourceDictionary>, ApplicationResourceManager>();
|
services.AddSingleton<IApplicationResourceManager<ResourceDictionary>, ApplicationResourceManager>();
|
||||||
services.AddSingleton<IThemeService, ThemeService>();
|
services.AddSingleton<IThemeService, ThemeService>();
|
||||||
services.AddSingleton<IThemeService, ThemeService>();
|
|
||||||
services.AddSingleton<IPreferencesService, PreferencesService>();
|
services.AddSingleton<IPreferencesService, PreferencesService>();
|
||||||
services.AddSingleton<IStatePersistanceService, StatePersistenceService>();
|
services.AddSingleton<IStatePersistanceService, StatePersistenceService>();
|
||||||
services.AddSingleton<ILaunchProtocolService, LaunchProtocolService>();
|
services.AddSingleton<ILaunchProtocolService, LaunchProtocolService>();
|
||||||
@@ -141,6 +140,7 @@ namespace Wino
|
|||||||
services.AddTransient(typeof(MessageListPageViewModel));
|
services.AddTransient(typeof(MessageListPageViewModel));
|
||||||
services.AddTransient(typeof(ReadingPanePageViewModel));
|
services.AddTransient(typeof(ReadingPanePageViewModel));
|
||||||
services.AddTransient(typeof(MergedAccountDetailsPageViewModel));
|
services.AddTransient(typeof(MergedAccountDetailsPageViewModel));
|
||||||
|
services.AddTransient(typeof(LanguageTimePageViewModel));
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|||||||
@@ -18,6 +18,8 @@ namespace Wino.Helpers
|
|||||||
{
|
{
|
||||||
public static class XamlHelpers
|
public static class XamlHelpers
|
||||||
{
|
{
|
||||||
|
private const string TwentyFourHourTimeFormat = "HH:mm";
|
||||||
|
private const string TwelveHourTimeFormat = "hh:mm tt";
|
||||||
#region Converters
|
#region Converters
|
||||||
|
|
||||||
public static Visibility ReverseBoolToVisibilityConverter(bool value) => value ? Visibility.Collapsed : Visibility.Visible;
|
public static Visibility ReverseBoolToVisibilityConverter(bool value) => value ? Visibility.Collapsed : Visibility.Visible;
|
||||||
@@ -58,14 +60,14 @@ namespace Wino.Helpers
|
|||||||
{
|
{
|
||||||
var localTime = receivedDate.ToLocalTime();
|
var localTime = receivedDate.ToLocalTime();
|
||||||
|
|
||||||
return prefer24HourTime ? localTime.ToString("HH:mm") : localTime.ToString("hh:mm tt");
|
return prefer24HourTime ? localTime.ToString(TwentyFourHourTimeFormat) : localTime.ToString(TwelveHourTimeFormat);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static string GetCreationDateString(DateTime date)
|
public static string GetCreationDateString(DateTime date, bool prefer24HourTime)
|
||||||
{
|
{
|
||||||
var localTime = date.ToLocalTime();
|
var localTime = date.ToLocalTime();
|
||||||
return $"{localTime.ToLongDateString()} {localTime.ToLongTimeString()}";
|
return $"{localTime.ToLongDateString()} {(prefer24HourTime ? localTime.ToString(TwentyFourHourTimeFormat) : localTime.ToString(TwelveHourTimeFormat))}";
|
||||||
}
|
}
|
||||||
|
|
||||||
public static string GetMailGroupDateString(object groupObject)
|
public static string GetMailGroupDateString(object groupObject)
|
||||||
|
|||||||
6
Wino.Mail/Views/Abstract/LanguageTimePageAbstract.cs
Normal file
6
Wino.Mail/Views/Abstract/LanguageTimePageAbstract.cs
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
using Wino.Mail.ViewModels;
|
||||||
|
|
||||||
|
namespace Wino.Views.Abstract
|
||||||
|
{
|
||||||
|
public abstract class LanguageTimePageAbstract : BasePage<LanguageTimePageViewModel> { }
|
||||||
|
}
|
||||||
@@ -195,7 +195,7 @@
|
|||||||
<Run Text="<" /><Run Text="{x:Bind ViewModel.FromAddress, Mode=OneWay}" /><Run Text=">" />
|
<Run Text="<" /><Run Text="{x:Bind ViewModel.FromAddress, Mode=OneWay}" /><Run Text=">" />
|
||||||
</TextBlock>
|
</TextBlock>
|
||||||
</HyperlinkButton>
|
</HyperlinkButton>
|
||||||
<TextBlock FontSize="12" Text="{x:Bind helpers:XamlHelpers.GetCreationDateString(ViewModel.CreationDate), Mode=OneWay}" />
|
<TextBlock FontSize="12" Text="{x:Bind helpers:XamlHelpers.GetCreationDateString(ViewModel.CreationDate, ViewModel.PreferencesService.Prefer24HourTimeFormat), Mode=OneWay}" />
|
||||||
</StackPanel>
|
</StackPanel>
|
||||||
</Grid>
|
</Grid>
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|||||||
38
Wino.Mail/Views/Settings/LanguageTimePage.xaml
Normal file
38
Wino.Mail/Views/Settings/LanguageTimePage.xaml
Normal file
File diff suppressed because one or more lines are too long
19
Wino.Mail/Views/Settings/LanguageTimePage.xaml.cs
Normal file
19
Wino.Mail/Views/Settings/LanguageTimePage.xaml.cs
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
using Wino.Views.Abstract;
|
||||||
|
|
||||||
|
namespace Wino.Views.Settings
|
||||||
|
{
|
||||||
|
public sealed partial class LanguageTimePage : LanguageTimePageAbstract
|
||||||
|
{
|
||||||
|
public LanguageTimePage()
|
||||||
|
{
|
||||||
|
this.InitializeComponent();
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void OnLanguageChanged()
|
||||||
|
{
|
||||||
|
base.OnLanguageChanged();
|
||||||
|
|
||||||
|
Bindings.Update();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@@ -8,12 +8,5 @@ namespace Wino.Views.Settings
|
|||||||
{
|
{
|
||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
}
|
}
|
||||||
|
|
||||||
public override void OnLanguageChanged()
|
|
||||||
{
|
|
||||||
base.OnLanguageChanged();
|
|
||||||
|
|
||||||
Bindings.Update();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -46,22 +46,15 @@ namespace Wino.Views
|
|||||||
settingsHeader.Title = Translator.MenuSettings;
|
settingsHeader.Title = Translator.MenuSettings;
|
||||||
}
|
}
|
||||||
|
|
||||||
private Type GetNavigationPageType(WinoPage page)
|
private Type GetNavigationPageType(WinoPage page) => page switch
|
||||||
{
|
{
|
||||||
switch (page)
|
WinoPage.AboutPage => typeof(AboutPage),
|
||||||
{
|
WinoPage.PersonalizationPage => typeof(PersonalizationPage),
|
||||||
case WinoPage.AboutPage:
|
WinoPage.MessageListPage => typeof(MessageListPage),
|
||||||
return typeof(AboutPage);
|
WinoPage.ReadingPanePage => typeof(ReadingPanePage),
|
||||||
case WinoPage.PersonalizationPage:
|
WinoPage.LanguageTimePage => typeof(LanguageTimePage),
|
||||||
return typeof(PersonalizationPage);
|
_ => null,
|
||||||
case WinoPage.MessageListPage:
|
};
|
||||||
return typeof(MessageListPage);
|
|
||||||
case WinoPage.ReadingPanePage:
|
|
||||||
return typeof(ReadingPanePage);
|
|
||||||
default:
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void IRecipient<BreadcrumbNavigationRequested>.Receive(BreadcrumbNavigationRequested message)
|
void IRecipient<BreadcrumbNavigationRequested>.Receive(BreadcrumbNavigationRequested message)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -356,6 +356,7 @@
|
|||||||
<Compile Include="Views\Abstract\AppShellAbstract.cs" />
|
<Compile Include="Views\Abstract\AppShellAbstract.cs" />
|
||||||
<Compile Include="Views\Abstract\ComposePageAbstract.cs" />
|
<Compile Include="Views\Abstract\ComposePageAbstract.cs" />
|
||||||
<Compile Include="Views\Abstract\IdlePageAbstract.cs" />
|
<Compile Include="Views\Abstract\IdlePageAbstract.cs" />
|
||||||
|
<Compile Include="Views\Abstract\LanguageTimePageAbstract.cs" />
|
||||||
<Compile Include="Views\Abstract\MailListPageAbstract.cs" />
|
<Compile Include="Views\Abstract\MailListPageAbstract.cs" />
|
||||||
<Compile Include="Views\Abstract\MailRenderingPageAbstract.cs" />
|
<Compile Include="Views\Abstract\MailRenderingPageAbstract.cs" />
|
||||||
<Compile Include="Views\Abstract\MergedAccountDetailsPageAbstract.cs" />
|
<Compile Include="Views\Abstract\MergedAccountDetailsPageAbstract.cs" />
|
||||||
@@ -413,6 +414,9 @@
|
|||||||
<Compile Include="Views\Settings\AboutPage.xaml.cs">
|
<Compile Include="Views\Settings\AboutPage.xaml.cs">
|
||||||
<DependentUpon>AboutPage.xaml</DependentUpon>
|
<DependentUpon>AboutPage.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
|
<Compile Include="Views\Settings\LanguageTimePage.xaml.cs">
|
||||||
|
<DependentUpon>LanguageTimePage.xaml</DependentUpon>
|
||||||
|
</Compile>
|
||||||
<Compile Include="Views\Settings\MessageListPage.xaml.cs">
|
<Compile Include="Views\Settings\MessageListPage.xaml.cs">
|
||||||
<DependentUpon>MessageListPage.xaml</DependentUpon>
|
<DependentUpon>MessageListPage.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
@@ -626,6 +630,10 @@
|
|||||||
<SubType>Designer</SubType>
|
<SubType>Designer</SubType>
|
||||||
<Generator>MSBuild:Compile</Generator>
|
<Generator>MSBuild:Compile</Generator>
|
||||||
</Page>
|
</Page>
|
||||||
|
<Page Include="Views\Settings\LanguageTimePage.xaml">
|
||||||
|
<Generator>MSBuild:Compile</Generator>
|
||||||
|
<SubType>Designer</SubType>
|
||||||
|
</Page>
|
||||||
<Page Include="Views\Settings\MessageListPage.xaml">
|
<Page Include="Views\Settings\MessageListPage.xaml">
|
||||||
<SubType>Designer</SubType>
|
<SubType>Designer</SubType>
|
||||||
<Generator>MSBuild:Compile</Generator>
|
<Generator>MSBuild:Compile</Generator>
|
||||||
|
|||||||
Reference in New Issue
Block a user