Include expansionversion and NG+ chapter in QuestInfo

pull/15/head^2
Liza 2024-08-10 18:35:54 +02:00
parent c0e8a47ef6
commit 348460a7c6
Signed by: liza
GPG Key ID: 7199F8D727D55F67
9 changed files with 141 additions and 19 deletions

View File

@ -175,7 +175,7 @@ internal sealed class EditorCommands : IDisposable
{ {
var territoryInfo = _dataManager.GetExcelSheet<TerritoryType>()!.GetRow(_clientState.TerritoryType)!; var territoryInfo = _dataManager.GetExcelSheet<TerritoryType>()!.GetRow(_clientState.TerritoryType)!;
targetFolder = _plugin.PathsDirectory targetFolder = _plugin.PathsDirectory
.CreateSubdirectory(ExpansionData.ExpansionFolders[(byte)territoryInfo.ExVersion.Row]) .CreateSubdirectory(ExpansionData.ExpansionFolders[(EExpansionVersion)territoryInfo.ExVersion.Row])
.CreateSubdirectory(territoryInfo.PlaceName.Value!.Name.ToString()); .CreateSubdirectory(territoryInfo.PlaceName.Value!.Name.ToString());
} }

View File

@ -0,0 +1,27 @@
using System.Collections.Generic;
namespace Questionable.Model;
public enum EExpansionVersion : byte
{
ARealmReborn = 0,
Heavensward = 1,
Stormblood = 2,
Shadowbringers = 3,
Endwalker = 4,
Dawntrail = 5
}
public static class ExpansionData
{
public static IReadOnlyDictionary<EExpansionVersion, string> ExpansionFolders =
new Dictionary<EExpansionVersion, string>
{
{ EExpansionVersion.ARealmReborn, "2.x - A Realm Reborn" },
{ EExpansionVersion.Heavensward, "3.x - Heavensward" },
{ EExpansionVersion.Stormblood, "4.x - Stormblood" },
{ EExpansionVersion.Shadowbringers, "5.x - Shadowbringers" },
{ EExpansionVersion.Endwalker, "6.x - Endwalker" },
{ EExpansionVersion.Dawntrail, "7.x - Dawntrail" }
};
}

View File

@ -1,16 +0,0 @@
using System.Collections.Generic;
namespace Questionable.Model;
public static class ExpansionData
{
public static IReadOnlyDictionary<byte, string> ExpansionFolders = new Dictionary<byte, string>()
{
{ 0, "2.x - A Realm Reborn" },
{ 1, "3.x - Heavensward" },
{ 2, "4.x - Stormblood" },
{ 3, "5.x - Shadowbringers" },
{ 4, "6.x - Endwalker" },
{ 5, "7.x - Dawntrail" }
};
}

View File

@ -8,6 +8,7 @@ using System.Text.Json;
using System.Text.Json.Nodes; using System.Text.Json.Nodes;
using Dalamud.Plugin; using Dalamud.Plugin;
using Dalamud.Plugin.Ipc; using Dalamud.Plugin.Ipc;
using LLib.GameData;
using Microsoft.Extensions.Logging; using Microsoft.Extensions.Logging;
using Questionable.Data; using Questionable.Data;
using Questionable.Model; using Questionable.Model;
@ -203,4 +204,11 @@ internal sealed class QuestRegistry
public bool TryGetQuest(ElementId questId, [NotNullWhen(true)] out Quest? quest) public bool TryGetQuest(ElementId questId, [NotNullWhen(true)] out Quest? quest)
=> _quests.TryGetValue(questId, out quest); => _quests.TryGetValue(questId, out quest);
public List<QuestInfo> GetKnownClassJobQuests(EClassJob classJob)
{
return _questData.GetClassJobQuests(classJob)
.Where(x => IsKnownQuest(x.QuestId))
.ToList();
}
} }

View File

@ -15,12 +15,17 @@ internal sealed class QuestData
public QuestData(IDataManager dataManager) public QuestData(IDataManager dataManager)
{ {
Dictionary<uint, ushort> questChapters =
dataManager.GetExcelSheet<QuestChapter>()!
.Where(x => x.RowId > 0 && x.Quest.Row > 0)
.ToDictionary(x => x.Quest.Row, x => x.Redo);
List<IQuestInfo> quests = List<IQuestInfo> quests =
[ [
..dataManager.GetExcelSheet<Quest>()! ..dataManager.GetExcelSheet<Quest>()!
.Where(x => x.RowId > 0) .Where(x => x.RowId > 0)
.Where(x => x.IssuerLocation.Row > 0) .Where(x => x.IssuerLocation.Row > 0)
.Select(x => new QuestInfo(x)), .Select(x => new QuestInfo(x, questChapters.GetValueOrDefault(x.RowId))),
..dataManager.GetExcelSheet<SatisfactionNpc>()! ..dataManager.GetExcelSheet<SatisfactionNpc>()!
.Where(x => x.RowId > 0) .Where(x => x.RowId > 0)
.Select(x => new SatisfactionSupplyInfo(x)), .Select(x => new SatisfactionSupplyInfo(x)),
@ -56,4 +61,93 @@ internal sealed class QuestData
.ThenBy(x => x.QuestId) .ThenBy(x => x.QuestId)
.ToList(); .ToList();
} }
public List<QuestInfo> GetClassJobQuests(EClassJob classJob)
{
List<ushort> chapterIds = classJob switch
{
EClassJob.Adventurer => throw new ArgumentOutOfRangeException(nameof(classJob)),
// ARR
EClassJob.Gladiator => [63],
EClassJob.Paladin => [72, 73, 74, 75],
EClassJob.Marauder => [64],
EClassJob.Warrior => [76, 77, 78, 79],
EClassJob.Conjurer => [65],
EClassJob.WhiteMage => [86, 87, 88, 89],
EClassJob.Arcanist => [66],
EClassJob.Summoner => [127, 128, 129, 130],
EClassJob.Scholar => [90, 91, 92, 93],
EClassJob.Pugilist => [67],
EClassJob.Monk => [98, 99, 100, 101],
EClassJob.Lancer => [68],
EClassJob.Dragoon => [102, 103, 104, 105],
EClassJob.Rogue => [69],
EClassJob.Ninja => [106, 107, 108, 109],
EClassJob.Archer => [70],
EClassJob.Bard => [113, 114, 115, 116],
EClassJob.Thaumaturge => [71],
EClassJob.BlackMage => [123, 124, 125, 126],
// HW
EClassJob.DarkKnight => [80, 81, 82, 83],
EClassJob.Astrologian => [94, 95, 96, 97],
EClassJob.Machinist => [117, 118, 119, 120],
// SB
EClassJob.Samurai => [110, 111, 112],
EClassJob.RedMage => [131, 132, 133],
EClassJob.BlueMage => [134, 135, 146, 170],
// ShB
EClassJob.Gunbreaker => [84, 85],
EClassJob.Dancer => [121, 122],
// EW
EClassJob.Sage => [152],
EClassJob.Reaper => [153],
// DT
EClassJob.Viper => [176],
EClassJob.Pictomancer => [177],
// Crafter
EClassJob.Alchemist => [48, 49, 50],
EClassJob.Armorer => [36, 37, 38],
EClassJob.Blacksmith => [33, 34, 35],
EClassJob.Carpenter => [30, 31, 32],
EClassJob.Culinarian => [51, 52, 53],
EClassJob.Goldsmith => [39, 40, 41],
EClassJob.Leatherworker => [42, 43, 44],
EClassJob.Weaver => [45, 46, 47],
// Gatherer
EClassJob.Miner => [54, 55, 56],
EClassJob.Botanist => [57, 58, 59],
EClassJob.Fisher => [60, 61, 62],
_ => throw new ArgumentOutOfRangeException(nameof(classJob)),
};
chapterIds.AddRange(classJob switch
{
_ when classJob.IsTank() => [136, 154, 178],
_ when classJob.IsHealer() => [137, 155, 179],
_ when classJob.IsMelee() => [138, 156, 180],
_ when classJob.IsPhysicalRanged() => [138, 157, 181],
_ when classJob.IsCaster() && classJob != EClassJob.BlueMage => [139, 158, 182],
_ => []
});
return GetQuestsInNewGamePlusChapters(chapterIds);
}
private List<QuestInfo> GetQuestsInNewGamePlusChapters(List<ushort> chapterIds)
{
return _quests.Values
.Where(x => x is QuestInfo)
.Cast<QuestInfo>()
.Where(x => chapterIds.Contains(x.NewGamePlusChapter))
.ToList();
}
} }

View File

@ -16,6 +16,7 @@ public interface IQuestInfo
public EBeastTribe BeastTribe { get; } public EBeastTribe BeastTribe { get; }
public bool IsMainScenarioQuest { get; } public bool IsMainScenarioQuest { get; }
public IReadOnlyList<EClassJob> ClassJobs { get; } public IReadOnlyList<EClassJob> ClassJobs { get; }
public EExpansionVersion Expansion { get; }
public string SimplifiedName => Name public string SimplifiedName => Name
.Replace(".", "", StringComparison.Ordinal) .Replace(".", "", StringComparison.Ordinal)

View File

@ -14,6 +14,7 @@ internal sealed class LeveInfo : IQuestInfo
Level = leve.ClassJobLevel; Level = leve.ClassJobLevel;
IssuerDataId = leve.LevelLevemete.Value!.Object; IssuerDataId = leve.LevelLevemete.Value!.Object;
ClassJobs = QuestInfoUtils.AsList(leve.ClassJobCategory.Value!); ClassJobs = QuestInfoUtils.AsList(leve.ClassJobCategory.Value!);
Expansion = (EExpansionVersion)leve.LevelLevemete.Value.Territory.Value!.ExVersion.Row;
} }
public ElementId QuestId { get; } public ElementId QuestId { get; }
@ -24,4 +25,5 @@ internal sealed class LeveInfo : IQuestInfo
public EBeastTribe BeastTribe => EBeastTribe.None; public EBeastTribe BeastTribe => EBeastTribe.None;
public bool IsMainScenarioQuest => false; public bool IsMainScenarioQuest => false;
public IReadOnlyList<EClassJob> ClassJobs { get; } public IReadOnlyList<EClassJob> ClassJobs { get; }
public EExpansionVersion Expansion { get; }
} }

View File

@ -11,7 +11,7 @@ namespace Questionable.Model;
internal sealed class QuestInfo : IQuestInfo internal sealed class QuestInfo : IQuestInfo
{ {
public QuestInfo(ExcelQuest quest) public QuestInfo(ExcelQuest quest, ushort newGamePlusChapter)
{ {
QuestId = new QuestId((ushort)(quest.RowId & 0xFFFF)); QuestId = new QuestId((ushort)(quest.RowId & 0xFFFF));
@ -54,6 +54,8 @@ internal sealed class QuestInfo : IQuestInfo
BeastTribe = (EBeastTribe)quest.BeastTribe.Row; BeastTribe = (EBeastTribe)quest.BeastTribe.Row;
ClassJobs = QuestInfoUtils.AsList(quest.ClassJobCategory0.Value!); ClassJobs = QuestInfoUtils.AsList(quest.ClassJobCategory0.Value!);
IsSeasonalEvent = quest.Festival.Row != 0; IsSeasonalEvent = quest.Festival.Row != 0;
NewGamePlusChapter = newGamePlusChapter;
Expansion = (EExpansionVersion)quest.Expansion.Row;
} }
@ -76,6 +78,8 @@ internal sealed class QuestInfo : IQuestInfo
public EBeastTribe BeastTribe { get; } public EBeastTribe BeastTribe { get; }
public IReadOnlyList<EClassJob> ClassJobs { get; } public IReadOnlyList<EClassJob> ClassJobs { get; }
public bool IsSeasonalEvent { get; } public bool IsSeasonalEvent { get; }
public ushort NewGamePlusChapter { get; }
public EExpansionVersion Expansion { get; }
[UsedImplicitly(ImplicitUseKindFlags.Assign, ImplicitUseTargetFlags.Members)] [UsedImplicitly(ImplicitUseKindFlags.Assign, ImplicitUseTargetFlags.Members)]
public enum QuestJoin : byte public enum QuestJoin : byte

View File

@ -13,6 +13,7 @@ internal sealed class SatisfactionSupplyInfo : IQuestInfo
Name = npc.Npc.Value!.Singular; Name = npc.Npc.Value!.Singular;
IssuerDataId = npc.Npc.Row; IssuerDataId = npc.Npc.Row;
Level = npc.LevelUnlock; Level = npc.LevelUnlock;
Expansion = (EExpansionVersion)npc.QuestRequired.Value!.Expansion.Row;
} }
public ElementId QuestId { get; } public ElementId QuestId { get; }
@ -22,6 +23,7 @@ internal sealed class SatisfactionSupplyInfo : IQuestInfo
public ushort Level { get; } public ushort Level { get; }
public EBeastTribe BeastTribe => EBeastTribe.None; public EBeastTribe BeastTribe => EBeastTribe.None;
public bool IsMainScenarioQuest => false; public bool IsMainScenarioQuest => false;
public EExpansionVersion Expansion { get; }
/// <summary> /// <summary>
/// We don't have collectables implemented for any other class. /// We don't have collectables implemented for any other class.