Configurable notifications

This commit is contained in:
Eddoursul 2022-08-18 11:47:06 +02:00
parent 3ee609540b
commit 804504e7a2
3 changed files with 22 additions and 6 deletions

View File

@ -1,2 +1,4 @@
LoadSuppliesEverywhere = false LoadSuppliesEverywhere = false
StoreInventorySupplies = true StoreInventorySupplies = true
ShowFetchingNotification = true
ShowReturningNotification = false

View File

@ -58,6 +58,8 @@ inline const std::map<std::string, bool> GetSettings(bool bInit = false)
if (bInit) { if (bInit) {
settings.insert({ "LoadSuppliesEverywhere", false }); settings.insert({ "LoadSuppliesEverywhere", false });
settings.insert({ "StoreInventorySupplies", true }); settings.insert({ "StoreInventorySupplies", true });
settings.insert({ "ShowFetchingNotification", true });
settings.insert({ "ShowReturningNotification", false });
LoadINI(&settings, "Data/SKSE/Plugins/EnderalSEEasyCrafting.ini"); LoadINI(&settings, "Data/SKSE/Plugins/EnderalSEEasyCrafting.ini");
} }
return settings; return settings;
@ -99,7 +101,9 @@ inline void ReturnSupplies()
bSuppliesFetched = false; bSuppliesFetched = false;
//RE::DebugNotification("Returning supplies..."); if (GetSettings().at("ShowReturningNotification")) {
RE::DebugNotification("Returning supplies...");
}
const auto chest = RE::TESForm::LookupByID(0x5C132)->As<RE::TESObjectREFR>(); const auto chest = RE::TESForm::LookupByID(0x5C132)->As<RE::TESObjectREFR>();
const auto playerRef = RE::PlayerCharacter::GetSingleton(); const auto playerRef = RE::PlayerCharacter::GetSingleton();
@ -202,24 +206,34 @@ inline void FetchSupplies(RE::TESFurniture* a_furn)
std::thread([a_furn]() { std::thread([a_furn]() {
std::this_thread::sleep_for(std::chrono::milliseconds(1)); std::this_thread::sleep_for(std::chrono::milliseconds(1));
SKSE::GetTaskInterface()->AddTask([a_furn]() { SKSE::GetTaskInterface()->AddTask([a_furn]() {
bool bNotify = GetSettings().at("ShowFetchingNotification");
switch (a_furn->workBenchData.benchType.underlying()) { switch (a_furn->workBenchData.benchType.underlying()) {
case (int)RE::TESFurniture::WorkBenchData::BenchType::kAlchemy: case (int)RE::TESFurniture::WorkBenchData::BenchType::kAlchemy:
case (int)RE::TESFurniture::WorkBenchData::BenchType::kAlchemyExperiment: case (int)RE::TESFurniture::WorkBenchData::BenchType::kAlchemyExperiment:
if (bNotify) {
RE::DebugNotification("Fetching ingredients..."); RE::DebugNotification("Fetching ingredients...");
}
FetchSuppliesByType(RE::FormType::Ingredient); FetchSuppliesByType(RE::FormType::Ingredient);
break; break;
case (int)RE::TESFurniture::WorkBenchData::BenchType::kEnchanting: case (int)RE::TESFurniture::WorkBenchData::BenchType::kEnchanting:
case (int)RE::TESFurniture::WorkBenchData::BenchType::kEnchantingExperiment: case (int)RE::TESFurniture::WorkBenchData::BenchType::kEnchantingExperiment:
if (bNotify) {
RE::DebugNotification("Fetching soul gems..."); RE::DebugNotification("Fetching soul gems...");
}
FetchSuppliesByType(RE::FormType::SoulGem); FetchSuppliesByType(RE::FormType::SoulGem);
break; break;
default: default:
if (a_furn->As<RE::BGSKeywordForm>()->HasKeywordString("CraftingCookpot")) { if (a_furn->As<RE::BGSKeywordForm>()->HasKeywordString("CraftingCookpot")) {
if (bNotify) {
RE::DebugNotification("Fetching cooking ingredients..."); RE::DebugNotification("Fetching cooking ingredients...");
}
FetchSuppliesByType(RE::FormType::Ingredient); FetchSuppliesByType(RE::FormType::Ingredient);
FetchSuppliesByType(RE::FormType::AlchemyItem); FetchSuppliesByType(RE::FormType::AlchemyItem);
} else { } else {
if (bNotify) {
RE::DebugNotification("Fetching crafting supplies..."); RE::DebugNotification("Fetching crafting supplies...");
}
FetchSuppliesByType(RE::FormType::Misc); FetchSuppliesByType(RE::FormType::Misc);
FetchSuppliesByType(RE::FormType::Ingredient); FetchSuppliesByType(RE::FormType::Ingredient);
FetchSuppliesByType(RE::FormType::SoulGem); FetchSuppliesByType(RE::FormType::SoulGem);