From 57e57397d2f25b5cd91d5552de4d72f9fd9abdaf Mon Sep 17 00:00:00 2001 From: qhy040404 Date: Fri, 13 Sep 2024 08:57:57 +0800 Subject: [PATCH 1/2] #897 #1907 --- .../Snap.Hutao/Model/Intrinsic/QuestType.cs | 2 +- .../Model/Metadata/Achievement/Achievement.cs | 5 +++ .../Snap.Hutao/Resource/Localization/SH.resx | 3 ++ .../UI/Xaml/View/Page/AchievementPage.xaml | 5 +++ .../Achievement/AchievementViewModel.cs | 35 +++++++++++++++++-- 5 files changed, 47 insertions(+), 3 deletions(-) diff --git a/src/Snap.Hutao/Snap.Hutao/Model/Intrinsic/QuestType.cs b/src/Snap.Hutao/Snap.Hutao/Model/Intrinsic/QuestType.cs index d11e108b12..591d59aecd 100644 --- a/src/Snap.Hutao/Snap.Hutao/Model/Intrinsic/QuestType.cs +++ b/src/Snap.Hutao/Snap.Hutao/Model/Intrinsic/QuestType.cs @@ -31,7 +31,7 @@ internal enum QuestType : uint DQ, /// - /// Indescribable Quest 不可描述的任务? + /// Interval Quest 间隔任务? /// IQ, diff --git a/src/Snap.Hutao/Snap.Hutao/Model/Metadata/Achievement/Achievement.cs b/src/Snap.Hutao/Snap.Hutao/Model/Metadata/Achievement/Achievement.cs index ba2e8cbf4a..e0e11d9c82 100644 --- a/src/Snap.Hutao/Snap.Hutao/Model/Metadata/Achievement/Achievement.cs +++ b/src/Snap.Hutao/Snap.Hutao/Model/Metadata/Achievement/Achievement.cs @@ -55,4 +55,9 @@ internal sealed class Achievement /// 版本 /// public string Version { get; set; } = default!; + + /// + /// 是否为委托成就 + /// + public bool IsDailyQuest { get; set; } } \ No newline at end of file diff --git a/src/Snap.Hutao/Snap.Hutao/Resource/Localization/SH.resx b/src/Snap.Hutao/Snap.Hutao/Resource/Localization/SH.resx index 481a4f18ee..2cd1c7cedb 100644 --- a/src/Snap.Hutao/Snap.Hutao/Resource/Localization/SH.resx +++ b/src/Snap.Hutao/Snap.Hutao/Resource/Localization/SH.resx @@ -2006,6 +2006,9 @@ 导出 + + 仅委托成就 + 从剪贴板导入 diff --git a/src/Snap.Hutao/Snap.Hutao/UI/Xaml/View/Page/AchievementPage.xaml b/src/Snap.Hutao/Snap.Hutao/UI/Xaml/View/Page/AchievementPage.xaml index af11aafbf2..6fed33122a 100644 --- a/src/Snap.Hutao/Snap.Hutao/UI/Xaml/View/Page/AchievementPage.xaml +++ b/src/Snap.Hutao/Snap.Hutao/UI/Xaml/View/Page/AchievementPage.xaml @@ -328,6 +328,11 @@ Icon="{shuxm:FontIcon Glyph=}" IsChecked="{Binding IsUncompletedItemsFirst, Mode=TwoWay}" Label="{shuxm:ResourceString Name=ViewPageAchievementSortIncompletedItemsFirst}"/> + diff --git a/src/Snap.Hutao/Snap.Hutao/ViewModel/Achievement/AchievementViewModel.cs b/src/Snap.Hutao/Snap.Hutao/ViewModel/Achievement/AchievementViewModel.cs index 71ff29c700..b4fc469e05 100644 --- a/src/Snap.Hutao/Snap.Hutao/ViewModel/Achievement/AchievementViewModel.cs +++ b/src/Snap.Hutao/Snap.Hutao/ViewModel/Achievement/AchievementViewModel.cs @@ -40,6 +40,7 @@ internal sealed partial class AchievementViewModel : Abstraction.ViewModel, INav private IAdvancedDbCollectionView? archives; private bool isUncompletedItemsFirst = true; + private bool onlyShowDailyQuestItems; private string searchText = string.Empty; private string? finishDescription; @@ -99,6 +100,12 @@ public bool IsUncompletedItemsFirst set => SetProperty(ref isUncompletedItemsFirst, value); } + public bool OnlyShowDailyQuestItems + { + get => onlyShowDailyQuestItems; + set => SetProperty(ref onlyShowDailyQuestItems, value); + } + public string? FinishDescription { get => finishDescription; @@ -374,28 +381,31 @@ private void UpdateAchievementsFilterByGoal(AchievementGoalView? goal) [Command("SearchAchievementCommand")] private void UpdateAchievementsFilterBySearch(string? search) { - if (Achievements is null) + if (Achievements is null || AchievementGoals is null) { return; } - AchievementGoals?.MoveCurrentTo(default); + AchievementGoals.MoveCurrentTo(default); if (string.IsNullOrEmpty(search)) { Achievements.Filter = default!; + AchievementGoals.Filter = default!; return; } if (uint.TryParse(search, out uint achievementId)) { Achievements.Filter = view => view.Inner.Id == achievementId; + AchievementGoals.Filter = goal => Achievements.View.FirstOrDefault(view => view.Inner.Goal == goal.Id) is not null; return; } if (VersionRegex().IsMatch(search)) { Achievements.Filter = view => view.Inner.Version == search; + AchievementGoals.Filter = goal => Achievements.View.FirstOrDefault(view => view.Inner.Goal == goal.Id) is not null; return; } @@ -404,6 +414,7 @@ private void UpdateAchievementsFilterBySearch(string? search) return view.Inner.Title.Contains(search, StringComparison.CurrentCultureIgnoreCase) || view.Inner.Description.Contains(search, StringComparison.CurrentCultureIgnoreCase); }; + AchievementGoals.Filter = goal => Achievements.View.FirstOrDefault(view => view.Inner.Goal == goal.Id) is not null; } [Command("SaveAchievementCommand")] @@ -417,4 +428,24 @@ private void SaveAchievement(AchievementView? achievement) scopeContext.AchievementService.SaveAchievement(achievement); AchievementFinishPercent.Update(this); } + + [Command("FilterDailyQuestSwitchCommand")] + private void UpdateAchievementsFilterByDailyQuest() + { + if (Achievements is null || AchievementGoals is null) + { + return; + } + + if (OnlyShowDailyQuestItems) + { + Achievements.Filter = (AchievementView view) => view.Inner.IsDailyQuest; + AchievementGoals.Filter = goal => Achievements.View.FirstOrDefault(view => view.Inner.Goal == goal.Id) is not null; + } + else + { + Achievements.Filter = default!; + AchievementGoals.Filter = default!; + } + } } \ No newline at end of file From 71f14ca69319d7ed8a599c1187dadf964432286b Mon Sep 17 00:00:00 2001 From: qhy040404 Date: Fri, 13 Sep 2024 09:30:36 +0800 Subject: [PATCH 2/2] rename variables --- .../Snap.Hutao/UI/Xaml/View/Page/AchievementPage.xaml | 2 +- .../ViewModel/Achievement/AchievementViewModel.cs | 10 +++++----- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/src/Snap.Hutao/Snap.Hutao/UI/Xaml/View/Page/AchievementPage.xaml b/src/Snap.Hutao/Snap.Hutao/UI/Xaml/View/Page/AchievementPage.xaml index 6fed33122a..390c766c74 100644 --- a/src/Snap.Hutao/Snap.Hutao/UI/Xaml/View/Page/AchievementPage.xaml +++ b/src/Snap.Hutao/Snap.Hutao/UI/Xaml/View/Page/AchievementPage.xaml @@ -331,7 +331,7 @@ diff --git a/src/Snap.Hutao/Snap.Hutao/ViewModel/Achievement/AchievementViewModel.cs b/src/Snap.Hutao/Snap.Hutao/ViewModel/Achievement/AchievementViewModel.cs index b4fc469e05..4a5caa3241 100644 --- a/src/Snap.Hutao/Snap.Hutao/ViewModel/Achievement/AchievementViewModel.cs +++ b/src/Snap.Hutao/Snap.Hutao/ViewModel/Achievement/AchievementViewModel.cs @@ -40,7 +40,7 @@ internal sealed partial class AchievementViewModel : Abstraction.ViewModel, INav private IAdvancedDbCollectionView? archives; private bool isUncompletedItemsFirst = true; - private bool onlyShowDailyQuestItems; + private bool filterDailyQuestItems; private string searchText = string.Empty; private string? finishDescription; @@ -100,10 +100,10 @@ public bool IsUncompletedItemsFirst set => SetProperty(ref isUncompletedItemsFirst, value); } - public bool OnlyShowDailyQuestItems + public bool FilterDailyQuestItems { - get => onlyShowDailyQuestItems; - set => SetProperty(ref onlyShowDailyQuestItems, value); + get => filterDailyQuestItems; + set => SetProperty(ref filterDailyQuestItems, value); } public string? FinishDescription @@ -437,7 +437,7 @@ private void UpdateAchievementsFilterByDailyQuest() return; } - if (OnlyShowDailyQuestItems) + if (FilterDailyQuestItems) { Achievements.Filter = (AchievementView view) => view.Inner.IsDailyQuest; AchievementGoals.Filter = goal => Achievements.View.FirstOrDefault(view => view.Inner.Goal == goal.Id) is not null;