* feat(preferences): ✨ Add email sync interval setting Introduced a new property `EmailSyncIntervalMinutes` in the `IPreferencesService` interface to allow users to configure the email synchronization interval in minutes. This feature enhances user control over email sync behavior. • Updated `resources.json` to include translations for the new setting. • Implemented the logic for the new property in `PreferencesService.cs`, with a default value of 3 minutes. • Added binding and UI support in `AppPreferencesPageViewModel.cs` and `AppPreferencesPage.xaml` to allow users to modify the sync interval. • Integrated the new setting into `ServerContext.cs` to dynamically adjust the synchronization timer based on user preferences. This change improves the user experience by providing customizable email synchronization settings. * Minimum interval and added an icon. * Proper SetProperty usage. * Making sure the minimum sync interval is 1 in the ServerContext. * Making sure the minimum is applied to first trigger of the sync timer. --------- Co-authored-by: Burak Kaan Köse <bkaankose@outlook.com>
229 lines
6.5 KiB
C#
229 lines
6.5 KiB
C#
using System;
|
|
using System.ComponentModel;
|
|
using Wino.Core.Domain.Enums;
|
|
using Wino.Core.Domain.Models.Calendar;
|
|
using Wino.Core.Domain.Models.Reader;
|
|
|
|
namespace Wino.Core.Domain.Interfaces;
|
|
|
|
public interface IPreferencesService: INotifyPropertyChanged
|
|
{
|
|
/// <summary>
|
|
/// When any of the preferences are changed.
|
|
/// </summary>
|
|
event EventHandler<string> PreferenceChanged;
|
|
|
|
#region Common
|
|
|
|
/// <summary>
|
|
/// Setting: Whether logs are enabled or not.
|
|
/// </summary>
|
|
bool IsLoggingEnabled { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Display language for the application.
|
|
/// </summary>
|
|
AppLanguage CurrentLanguage { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Whether the navigation pane is opened on the last session or not.
|
|
/// </summary>
|
|
bool IsNavigationPaneOpened { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Gets or sets what should happen to server app when the client is terminated.
|
|
/// </summary>
|
|
ServerBackgroundMode ServerTerminationBehavior { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Preferred time format for mail or calendar header display.
|
|
/// </summary>
|
|
bool Prefer24HourTimeFormat { get; set; }
|
|
|
|
/// <summary>
|
|
/// Diagnostic ID for the application.
|
|
/// Changes per-install.
|
|
/// </summary>
|
|
string DiagnosticId { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Defines the user's preference of default search mode in mail list.
|
|
/// Local search will still offer online search at the end of local search results.
|
|
/// </summary>
|
|
SearchMode DefaultSearchMode { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Interval in minutes for background email synchronization.
|
|
/// </summary>
|
|
int EmailSyncIntervalMinutes { get; set; }
|
|
|
|
#endregion
|
|
|
|
#region Mail
|
|
|
|
/// <summary>
|
|
/// Setting: For changing the mail display container mode.
|
|
/// </summary>
|
|
MailListDisplayMode MailItemDisplayMode { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Marking the item as read preference mode.
|
|
/// </summary>
|
|
MailMarkAsOption MarkAsPreference { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: How many seconds should be waited on rendering page to mark item as read.
|
|
/// </summary>
|
|
int MarkAsDelay { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Ask comfirmation from the user during permanent delete.
|
|
/// </summary>
|
|
bool IsHardDeleteProtectionEnabled { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Thread mails into conversations.
|
|
/// </summary>
|
|
bool IsThreadingEnabled { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Show sender pictures in mail list.
|
|
/// </summary>
|
|
bool IsShowSenderPicturesEnabled { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Show preview text in mail list.
|
|
/// </summary>
|
|
bool IsShowPreviewEnabled { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Enable/disable semantic zoom on clicking date headers.
|
|
/// </summary>
|
|
bool IsSemanticZoomEnabled { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Set whether 'img' tags in rendered HTMLs should be removed.
|
|
/// </summary>
|
|
bool RenderImages { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Set whether 'style' tags in rendered HTMls should be removed.
|
|
/// </summary>
|
|
bool RenderStyles { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Set whether plaintext links should be automatically converted to clickable links.
|
|
/// </summary>
|
|
bool RenderPlaintextLinks { get; set; }
|
|
|
|
/// <summary>
|
|
/// Gets the preferred rendering options for HTML rendering.
|
|
/// </summary>
|
|
MailRenderingOptions GetRenderingOptions();
|
|
|
|
/// <summary>
|
|
/// Setting: Swipe mail operation when mails are swiped to right.
|
|
/// </summary>
|
|
MailOperation RightSwipeOperation { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Swipe mail operation when mails are swiped to left.
|
|
/// </summary>
|
|
MailOperation LeftSwipeOperation { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Whether hover actions on mail pointer hover is enabled or not.
|
|
/// </summary>
|
|
bool IsHoverActionsEnabled { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Hover action on the left when the mail is hovered over.
|
|
/// </summary>
|
|
MailOperation LeftHoverAction { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Hover action on the center when the mail is hovered over.
|
|
/// </summary>
|
|
MailOperation CenterHoverAction { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Hover action on the right when the mail is hovered over.
|
|
/// </summary>
|
|
MailOperation RightHoverAction { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Whether Mailkit Protocol Logger is enabled for ImapTestService or not.
|
|
/// </summary>
|
|
bool IsMailkitProtocolLoggerEnabled { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Which entity id (merged account or folder) should be expanded automatically on startup.
|
|
/// </summary>
|
|
Guid? StartupEntityId { get; set; }
|
|
|
|
|
|
|
|
/// <summary>
|
|
/// Setting: Display font for the mail reader.
|
|
/// </summary>
|
|
string ReaderFont { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Font size for the mail reader.
|
|
/// </summary>
|
|
int ReaderFontSize { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Display font for the mail composer.
|
|
/// </summary>
|
|
string ComposerFont { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Font size for the mail composer.
|
|
/// </summary>
|
|
int ComposerFontSize { get; set; }
|
|
|
|
|
|
|
|
/// <summary>
|
|
/// Setting: Whether the next item should be automatically selected once the current item is moved or removed.
|
|
/// </summary>
|
|
bool AutoSelectNextItem { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Whether the mail list action bar is enabled or not.
|
|
/// </summary>
|
|
bool IsMailListActionBarEnabled { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Whether the mail rendering page will show the action labels
|
|
/// </summary>
|
|
bool IsShowActionLabelsEnabled { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Enable/disable Gravatar for sender avatars.
|
|
/// </summary>
|
|
bool IsGravatarEnabled { get; set; }
|
|
|
|
/// <summary>
|
|
/// Setting: Enable/disable Favicon for sender avatars.
|
|
/// </summary>
|
|
bool IsFaviconEnabled { get; set; }
|
|
|
|
#endregion
|
|
|
|
#region Calendar
|
|
|
|
DayOfWeek FirstDayOfWeek { get; set; }
|
|
TimeSpan WorkingHourStart { get; set; }
|
|
TimeSpan WorkingHourEnd { get; set; }
|
|
DayOfWeek WorkingDayStart { get; set; }
|
|
DayOfWeek WorkingDayEnd { get; set; }
|
|
double HourHeight { get; set; }
|
|
|
|
|
|
CalendarSettings GetCurrentCalendarSettings();
|
|
|
|
#endregion
|
|
}
|