From 70efb83f84400bc07f3fdd29f44c779af3af93c4 Mon Sep 17 00:00:00 2001 From: Sonaza Date: Tue, 1 Oct 2019 20:35:54 +0300 Subject: [PATCH] Fixed artifact module getting randomly disabled --- CHANGELOG.md | 3 +++ Experiencer.toc | 2 +- modules/artifact.lua | 62 ++++++++++++++++++++++++++++---------------- 3 files changed, 43 insertions(+), 24 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 61d8d4d..5625869 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,6 @@ +## 3.1.2 +* Fixed artifact module getting randomly disabled when changing zones. + ## 3.1.1 * Fixed changed Recruit-A-Friend check function call. Can't find specs on the level ranges so now it just calculates bonuses for anything up to level 120. * Fixed initial game load spouting total garbage values for everything, causing the addon think some bars were inactive/disabled. Selected bars shouldn't reset on game startup now. diff --git a/Experiencer.toc b/Experiencer.toc index e19fff5..70cf39d 100644 --- a/Experiencer.toc +++ b/Experiencer.toc @@ -2,7 +2,7 @@ ## Title: Experiencer ## Notes: Simple but advanced tracking progress bar addon ## Author: Sonaza -## Version: 3.1.1 +## Version: 3.1.2 ## OptionalDeps: Ace3 ## SavedVariables: ExperiencerDB, ExperiencerDB_module_experience, ExperiencerDB_module_reputation, ExperiencerDB_module_artifact, ExperiencerDB_module_honor, ExperiencerDB_module_conquest diff --git a/modules/artifact.lua b/modules/artifact.lua index dd0c84d..2dc9726 100644 --- a/modules/artifact.lua +++ b/modules/artifact.lua @@ -21,30 +21,45 @@ local module = Addon:RegisterModule("artifact", { module.levelUpRequiresAction = true; module.hasCustomMouseCallback = false; +module.hasArtifact = true; + function module:Initialize() self:RegisterEvent("AZERITE_ITEM_EXPERIENCE_CHANGED"); + self:RegisterEvent("UNIT_INVENTORY_CHANGED"); module.apInSession = 0; + + module:UpdateHasArtifact(); end -local HEART_OF_AZEROTH_ITEM_ID = 158075; -local HEART_OF_AZEROTH_QUEST_ID = 51211; +function module:UNIT_INVENTORY_CHANGED(event, unit) + if (unit ~= "player") then return end + module:UpdateHasArtifact(); + module:Refresh(); +end function module:IsDisabled() + return not module.hasArtifact; +end + +local HEART_OF_AZEROTH_ITEM_ID = 158075; +local HEART_OF_AZEROTH_QUEST_ID = 51211; + +function module:UpdateHasArtifact() local playerLevel = UnitLevel("player"); if (playerLevel < 110) then - return true; - end - - local hasArtifact = C_AzeriteItem.HasActiveAzeriteItem(); - if (not hasArtifact) then - -- C_AzeriteItem.HasActiveAzeriteItem may return false - -- during initial game loading, try a fallback to item id - local itemId = GetInventoryItemID("player", 2); - if (itemId == HEART_OF_AZEROTH_ITEM_ID) then - hasArtifact = true; + module.hasArtifact = false; + else + local hasArtifact = C_AzeriteItem.HasActiveAzeriteItem(); + if (not hasArtifact) then + -- C_AzeriteItem.HasActiveAzeriteItem may return false + -- during initial game loading, try a fallback to item id + local itemId = GetInventoryItemID("player", 2); + if (itemId == HEART_OF_AZEROTH_ITEM_ID) then + hasArtifact = true; + end end + module.hasArtifact = hasArtifact; end - return not hasArtifact; end function module:AllowedToBufferUpdate() @@ -68,25 +83,26 @@ function module:FormatNumber(value) end function module:GetArtifactName() - local azeriteItemLocation = C_AzeriteItem.FindActiveAzeriteItem(); - if (not azeriteItemLocation) then - return "Azerite Artifact"; - end - - -- idk if the azeriteItemLocation.equipmentSlotIndex has changed or whatever - --local itemID = GetInventoryItemID("player", azeriteItemLocation.equipmentSlotIndex); - local itemID = GetInventoryItemID("player", 2); -- can probably hardcode the neck with its slot id - if (itemID == nil) then return "Unknown" end + --local azeriteItemLocation = C_AzeriteItem.FindActiveAzeriteItem(); + --if (not azeriteItemLocation) then + -- return "Azerite Artifact"; + --end + --local itemID = GetInventoryItemID("player", 2); -- can probably hardcode the neck with its slot id + --if (itemID == nil) then return "Unknown" end + + local itemID = HEART_OF_AZEROTH_ITEM_ID; local name = GetItemInfo(itemID); if (not name) then self:RegisterEvent("GET_ITEM_INFO_RECEIVED"); + else + self:UnregisterEvent("GET_ITEM_INFO_RECEIVED"); end return name; end function module:GetText() - if(not C_AzeriteItem.HasActiveAzeriteItem()) then + if (module:IsDisabled()) then return "No artifact"; end