Merge pull request #168 from Tiktack/language-time-page
Language & Time page
This commit is contained in:
@@ -113,7 +113,6 @@ namespace Wino
|
||||
{
|
||||
services.AddSingleton<IApplicationResourceManager<ResourceDictionary>, ApplicationResourceManager>();
|
||||
services.AddSingleton<IThemeService, ThemeService>();
|
||||
services.AddSingleton<IThemeService, ThemeService>();
|
||||
services.AddSingleton<IPreferencesService, PreferencesService>();
|
||||
services.AddSingleton<IStatePersistanceService, StatePersistenceService>();
|
||||
services.AddSingleton<ILaunchProtocolService, LaunchProtocolService>();
|
||||
@@ -141,6 +140,7 @@ namespace Wino
|
||||
services.AddTransient(typeof(MessageListPageViewModel));
|
||||
services.AddTransient(typeof(ReadingPanePageViewModel));
|
||||
services.AddTransient(typeof(MergedAccountDetailsPageViewModel));
|
||||
services.AddTransient(typeof(LanguageTimePageViewModel));
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
@@ -18,6 +18,8 @@ namespace Wino.Helpers
|
||||
{
|
||||
public static class XamlHelpers
|
||||
{
|
||||
private const string TwentyFourHourTimeFormat = "HH:mm";
|
||||
private const string TwelveHourTimeFormat = "hh:mm tt";
|
||||
#region Converters
|
||||
|
||||
public static Visibility ReverseBoolToVisibilityConverter(bool value) => value ? Visibility.Collapsed : Visibility.Visible;
|
||||
@@ -58,14 +60,14 @@ namespace Wino.Helpers
|
||||
{
|
||||
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();
|
||||
return $"{localTime.ToLongDateString()} {localTime.ToLongTimeString()}";
|
||||
return $"{localTime.ToLongDateString()} {(prefer24HourTime ? localTime.ToString(TwentyFourHourTimeFormat) : localTime.ToString(TwelveHourTimeFormat))}";
|
||||
}
|
||||
|
||||
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=">" />
|
||||
</TextBlock>
|
||||
</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>
|
||||
</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();
|
||||
}
|
||||
|
||||
public override void OnLanguageChanged()
|
||||
{
|
||||
base.OnLanguageChanged();
|
||||
|
||||
Bindings.Update();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -46,22 +46,15 @@ namespace Wino.Views
|
||||
settingsHeader.Title = Translator.MenuSettings;
|
||||
}
|
||||
|
||||
private Type GetNavigationPageType(WinoPage page)
|
||||
private Type GetNavigationPageType(WinoPage page) => page switch
|
||||
{
|
||||
switch (page)
|
||||
{
|
||||
case WinoPage.AboutPage:
|
||||
return typeof(AboutPage);
|
||||
case WinoPage.PersonalizationPage:
|
||||
return typeof(PersonalizationPage);
|
||||
case WinoPage.MessageListPage:
|
||||
return typeof(MessageListPage);
|
||||
case WinoPage.ReadingPanePage:
|
||||
return typeof(ReadingPanePage);
|
||||
default:
|
||||
return null;
|
||||
}
|
||||
}
|
||||
WinoPage.AboutPage => typeof(AboutPage),
|
||||
WinoPage.PersonalizationPage => typeof(PersonalizationPage),
|
||||
WinoPage.MessageListPage => typeof(MessageListPage),
|
||||
WinoPage.ReadingPanePage => typeof(ReadingPanePage),
|
||||
WinoPage.LanguageTimePage => typeof(LanguageTimePage),
|
||||
_ => null,
|
||||
};
|
||||
|
||||
void IRecipient<BreadcrumbNavigationRequested>.Receive(BreadcrumbNavigationRequested message)
|
||||
{
|
||||
|
||||
@@ -356,6 +356,7 @@
|
||||
<Compile Include="Views\Abstract\AppShellAbstract.cs" />
|
||||
<Compile Include="Views\Abstract\ComposePageAbstract.cs" />
|
||||
<Compile Include="Views\Abstract\IdlePageAbstract.cs" />
|
||||
<Compile Include="Views\Abstract\LanguageTimePageAbstract.cs" />
|
||||
<Compile Include="Views\Abstract\MailListPageAbstract.cs" />
|
||||
<Compile Include="Views\Abstract\MailRenderingPageAbstract.cs" />
|
||||
<Compile Include="Views\Abstract\MergedAccountDetailsPageAbstract.cs" />
|
||||
@@ -413,6 +414,9 @@
|
||||
<Compile Include="Views\Settings\AboutPage.xaml.cs">
|
||||
<DependentUpon>AboutPage.xaml</DependentUpon>
|
||||
</Compile>
|
||||
<Compile Include="Views\Settings\LanguageTimePage.xaml.cs">
|
||||
<DependentUpon>LanguageTimePage.xaml</DependentUpon>
|
||||
</Compile>
|
||||
<Compile Include="Views\Settings\MessageListPage.xaml.cs">
|
||||
<DependentUpon>MessageListPage.xaml</DependentUpon>
|
||||
</Compile>
|
||||
@@ -626,6 +630,10 @@
|
||||
<SubType>Designer</SubType>
|
||||
<Generator>MSBuild:Compile</Generator>
|
||||
</Page>
|
||||
<Page Include="Views\Settings\LanguageTimePage.xaml">
|
||||
<Generator>MSBuild:Compile</Generator>
|
||||
<SubType>Designer</SubType>
|
||||
</Page>
|
||||
<Page Include="Views\Settings\MessageListPage.xaml">
|
||||
<SubType>Designer</SubType>
|
||||
<Generator>MSBuild:Compile</Generator>
|
||||
|
||||
Reference in New Issue
Block a user