From 0a35ea3eaa5b0066e3ebae2e99122e990f58476d Mon Sep 17 00:00:00 2001 From: Liza Carvelli Date: Fri, 3 Jan 2025 01:11:25 +0100 Subject: [PATCH] Add filter to exclude event rewards --- .../JournalComponents/QuestRewardComponent.cs | 20 ++++++++++++++++--- 1 file changed, 17 insertions(+), 3 deletions(-) diff --git a/Questionable/Windows/JournalComponents/QuestRewardComponent.cs b/Questionable/Windows/JournalComponents/QuestRewardComponent.cs index 2fab3109..cbb3af7d 100644 --- a/Questionable/Windows/JournalComponents/QuestRewardComponent.cs +++ b/Questionable/Windows/JournalComponents/QuestRewardComponent.cs @@ -1,5 +1,6 @@ using System; using System.Linq; +using Dalamud.Game.Text; using Dalamud.Interface.Utility.Raii; using ImGuiNET; using Questionable.Data; @@ -14,6 +15,8 @@ internal sealed class QuestRewardComponent private readonly QuestTooltipComponent _questTooltipComponent; private readonly UiUtils _uiUtils; + private bool _showEventRewards; + public QuestRewardComponent( QuestData questData, QuestTooltipComponent questTooltipComponent, @@ -30,7 +33,10 @@ internal sealed class QuestRewardComponent if (!tab) return; - ImGui.BulletText("Only untradeable items are listed (you can e.g. sell your Wind-up Airship from the enovy quest)."); + ImGui.Checkbox("Show rewards from seasonal event quests", ref _showEventRewards); + ImGui.Spacing(); + + ImGui.BulletText("Only untradeable items are listed (e.g. the Wind-up Airship can be sold on the market board)."); DrawGroup("Mounts", EItemRewardType.Mount); DrawGroup("Minions", EItemRewardType.Minion); @@ -47,9 +53,17 @@ internal sealed class QuestRewardComponent foreach (var item in _questData.RedeemableItems.Where(x => x.Type == type) .OrderBy(x => x.Name, StringComparer.CurrentCultureIgnoreCase)) { - if (_uiUtils.ChecklistItem(item.Name, item.IsUnlocked())) + if (_questData.TryGetQuestInfo(item.ElementId, out var questInfo)) { - if (_questData.TryGetQuestInfo(item.ElementId, out var questInfo)) + bool isEventQuest = questInfo is QuestInfo { IsSeasonalEvent: true }; + if (!_showEventRewards && isEventQuest) + continue; + + string name = item.Name; + if (isEventQuest) + name += $" {SeIconChar.Clock.ToIconString()}"; + + if (_uiUtils.ChecklistItem(name, item.IsUnlocked())) { using var tooltip = ImRaii.Tooltip(); if (!tooltip)