Nenue@33
|
1 -- WorldPlan
|
Nenue@33
|
2 -- WorldQuests.lua
|
Nenue@33
|
3 -- Created: 11/2/2016 3:40 PM
|
Nenue@33
|
4 -- %file-revision%
|
Nenue@72
|
5
|
Nenue@75
|
6 local print = DEVIAN_WORKSPACE and function(...) _G.print('WorldQuests', ...) end or nop
|
Nenue@75
|
7 local rprint = DEVIAN_WORKSPACE and function(...) _G.print('WQRefresh', ...) end or nop
|
Nenue@75
|
8 local qprint = DEVIAN_WORKSPACE and function(...) _G.print('POI', ...) end or nop
|
Nenue@75
|
9 local wprint = DEVIAN_WORKSPACE and function(...) _G.print('WP', ...) end or nop
|
Nenue@75
|
10 local mprint = DEVIAN_WORKSPACE and function(...) _G.print('Canvas', ...) end or nop
|
Nenue@40
|
11 local _, db = ...
|
Nenue@45
|
12 local Module = WorldPlanQuestsMixin
|
Nenue@33
|
13
|
Nick@64
|
14 local _G = _G
|
Nenue@72
|
15 local type, tostring, tonumber, pairs, ipairs = type, tostring, tonumber, pairs, ipairs
|
Nenue@33
|
16 local MC_GetNumZones, MC_GetZoneInfo = C_MapCanvas.GetNumZones, C_MapCanvas.GetZoneInfo
|
Nenue@33
|
17 local TQ_GetQuestsForPlayerByMapID = C_TaskQuest.GetQuestsForPlayerByMapID -- This function is not yet documented
|
Nenue@33
|
18 local TQ_GetQuestZoneID = C_TaskQuest.GetQuestZoneID
|
Nick@64
|
19 local TQ_IsActive = C_TaskQuest.IsActive
|
Nenue@75
|
20 local TQ_RequestPreloadRewardData = C_TaskQuest.RequestPreloadRewardData
|
Nick@64
|
21 local pairs, ipairs, tinsert, tremove, wipe = pairs, ipairs, tinsert, tremove, table.wipe
|
Nick@64
|
22 local GetTaskInfo, GetTasksTable, HaveQuestData = GetTaskInfo, GetTasksTable, HaveQuestData
|
Nick@64
|
23 local GetTime = GetTime
|
Nenue@69
|
24 local SpellCanTargetQuest, IsQuestIDValidSpellTarget = SpellCanTargetQuest, IsQuestIDValidSpellTarget
|
Nick@64
|
25 local tonumber, abs = tonumber, math.abs
|
Nick@64
|
26 local GetQuestLogRewardInfo = GetQuestLogRewardInfo
|
Nick@64
|
27 local GetCurrentMapAreaID, GetMapInfo, GetMapNameByID = GetCurrentMapAreaID, GetMapInfo, GetMapNameByID
|
Nenue@72
|
28 local GetQuestBountyInfoForMapID, GetQuestLogTitle, GetQuestLogIndexByID, IsQuestComplete = GetQuestBountyInfoForMapID, GetQuestLogTitle, GetQuestLogIndexByID, IsQuestComplete
|
Nenue@93
|
29 local HaveQuestRewardData = HaveQuestRewardData
|
Nenue@93
|
30 local TQ_GetQuestLocation = C_TaskQuest.GetQuestLocation
|
Nenue@96
|
31 local InCombatLockdown, hooksecurefunc = InCombatLockdown, hooksecurefunc
|
Nenue@33
|
32
|
Nenue@69
|
33 local ToggleButton = {}
|
Nenue@33
|
34 local BROKEN_ISLES_ID, DALARAN_ID, AZSUNA_ID, VALSHARAH_ID, HIGHMOUNTAIN_ID, STORMHEIM_ID, SURAMAR_ID, EOA_ID = 1007, 1014, 1015,1018, 1024, 1017, 1033, 1096
|
Nenue@33
|
35 local WORLD_QUEST_MAPS = { [DALARAN_ID] = 'Dalaran70', [AZSUNA_ID] = 'Azsuna', [VALSHARAH_ID] = "Val'sharah",
|
Nenue@33
|
36 [HIGHMOUNTAIN_ID] = 'Highmountain', [STORMHEIM_ID] = 'Stormheim', [SURAMAR_ID] = 'Suramar', [EOA_ID] = 'EyeOfAszhara', }
|
Nenue@33
|
37
|
Nenue@33
|
38 local REWARD_CASH = WORLD_QUEST_REWARD_TYPE_FLAG_GOLD
|
Nenue@33
|
39 local REWARD_ARTIFACT_POWER = WORLD_QUEST_REWARD_TYPE_FLAG_ARTIFACT_POWER
|
Nenue@33
|
40 local REWARD_GEAR = WORLD_QUEST_REWARD_TYPE_FLAG_EQUIPMENT
|
Nenue@33
|
41 local REWARD_CURRENCY = WORLD_QUEST_REWARD_TYPE_FLAG_ORDER_RESOURCES
|
Nenue@33
|
42 local REWARD_REAGENT = WORLD_QUEST_REWARD_TYPE_FLAG_MATERIALS
|
Nenue@72
|
43 local SCALE_FACTORS = { 0.25, 0.7, 1 }
|
Nenue@33
|
44
|
Nenue@72
|
45 local BountyBoard = WorldMapFrame.UIElementsFrame.BountyBoard
|
Nenue@72
|
46 local ActionButton = WorldMapFrame.UIElementsFrame.ActionButton
|
Nenue@93
|
47 local defaults = {}
|
Nenue@103
|
48 local completedQuests = {}
|
Nenue@72
|
49
|
Nenue@93
|
50 local continentScanned
|
Nenue@93
|
51 local layoutDirty = true
|
Nenue@93
|
52 local bountiesDirty = true
|
Nenue@93
|
53 local artifactPowerDirty = true
|
Nenue@96
|
54 local hooksDirty = true
|
Nenue@93
|
55 local currentScale = WorldMapDetailFrame:GetScale()
|
Nenue@93
|
56 local canTargetQuests
|
Nenue@93
|
57 local isDataLoaded = true
|
Nenue@93
|
58 local artifactKnowledgeLevel
|
Nenue@93
|
59 local superTrackedQuestID
|
Nenue@93
|
60 local lastRefresh
|
Nenue@93
|
61 local refreshReason
|
Nenue@93
|
62
|
Nenue@93
|
63 local bountyQuests = {}
|
Nenue@93
|
64 local bountyInfo = {}
|
Nenue@93
|
65 local bountyDisplayLocation, bountyLockedQuestID, selectedBountyIndex, selectedBountyQuestID
|
Nenue@93
|
66
|
Nenue@93
|
67 local totalPins = 0
|
Nenue@93
|
68 local numShown = 0
|
Nenue@93
|
69 local numLoaded = 0
|
Nenue@93
|
70 local numOverlays = 1
|
Nenue@93
|
71 local scaleConstant = 1
|
Nenue@100
|
72 local pinBaseIndex = 1550
|
Nenue@100
|
73 local overlayBaseIndex = 1600
|
Nenue@93
|
74
|
Nenue@93
|
75 local artifactKnowldegeSpells = {
|
Nenue@93
|
76 [207856] = true,
|
Nenue@93
|
77 [209203] = true,
|
Nenue@93
|
78 [209204] = true,
|
Nenue@93
|
79 [209205] = true,
|
Nenue@93
|
80 [209206] = true,
|
Nenue@93
|
81 [209207] = true,
|
Nenue@93
|
82 [209208] = true,
|
Nenue@93
|
83 [209209] = true,
|
Nenue@93
|
84 [209210] = true,
|
Nenue@93
|
85 [209211] = true,
|
Nenue@93
|
86 [209212] = true,
|
Nenue@93
|
87 [219978] = true,
|
Nenue@93
|
88 [227852] = true,
|
Nenue@93
|
89 [236477] = true,
|
Nenue@93
|
90 [236489] = true,
|
Nenue@93
|
91 [236302] = true,
|
Nenue@93
|
92 [236488] = true,
|
Nenue@93
|
93 [236490] = true,
|
Nenue@93
|
94 [240475] = true,
|
Nenue@93
|
95 [243176] = true,
|
Nenue@93
|
96 [243177] = true,
|
Nenue@93
|
97 [243178] = true,
|
Nenue@93
|
98 [243182] = true,
|
Nenue@93
|
99 [243183] = true,
|
Nenue@93
|
100 [243187] = true,
|
Nenue@93
|
101 [245133] = true,
|
Nenue@93
|
102 }
|
Nenue@33
|
103
|
Nenue@33
|
104 --%debug%
|
Nenue@33
|
105 local SetTimedCallbackForAllPins = function(seconds, callback)
|
Nenue@33
|
106 C_Timer.After(seconds, function()
|
Nenue@33
|
107 for id, pin in pairs(WorldPlanQuests.QuestsByID) do
|
Nenue@33
|
108 callback(pin)
|
Nenue@33
|
109 end
|
Nenue@33
|
110 end)
|
Nenue@33
|
111 end
|
Nenue@33
|
112
|
Nenue@93
|
113 function Module:OnLoad()
|
Nenue@93
|
114 --print('|cFFFF4400'..self:GetName()..':OnLoad()')
|
Nenue@52
|
115
|
Nenue@93
|
116 self:SetParent(WorldMapFrame.UIElementsFrame)
|
Nenue@93
|
117 WorldPlan:AddHandler(self, defaults)
|
Nenue@93
|
118
|
Nenue@93
|
119 for areaID, fileName in pairs(WORLD_QUEST_MAPS) do
|
Nenue@93
|
120 db.QuestsByZone[areaID] = {}
|
Nenue@33
|
121 end
|
Nenue@93
|
122
|
Nenue@93
|
123 -- WORLD_MAP_UPDATE and PLAYER_ENTERING_WORLD are passed down from a higher level
|
Nenue@93
|
124 self:RegisterEvent('WORLD_QUEST_COMPLETED_BY_SPELL')
|
Nenue@93
|
125 self:RegisterEvent('SUPER_TRACKED_QUEST_CHANGED')
|
Nenue@93
|
126 self:RegisterEvent('SKILL_LINES_CHANGED')
|
Nenue@93
|
127 self:RegisterEvent('ARTIFACT_UPDATE')
|
Nenue@93
|
128 self:RegisterEvent('QUEST_LOG_UPDATE')
|
Nenue@93
|
129 self:RegisterEvent('UNIT_SPELLCAST_STOP')
|
Nenue@93
|
130 end
|
Nenue@93
|
131
|
Nenue@93
|
132 function Module:OnEvent (event, ...)
|
Nenue@93
|
133 print('|cFFFFFF00OnEvent() '..event..'|r', GetTime(), ...)
|
Nenue@93
|
134 if (event == 'QUEST_LOG_UPDATE') then
|
Nenue@93
|
135 self:UpdateBounties(event)
|
Nenue@93
|
136 elseif event == 'WORLD_QUEST_COMPLETED_BY_SPELL' then
|
Nenue@93
|
137 local questID = ...
|
Nenue@93
|
138 if questID and db.QuestsByID[questID] then
|
Nenue@103
|
139 completedQuests[questID] = true
|
Nenue@93
|
140 db.QuestsByID[questID]:Release()
|
Nenue@93
|
141 end
|
Nenue@93
|
142 self:Refresh(event)
|
Nenue@93
|
143 elseif event == 'SKILL_LINES_CHANGED' or event == 'CURRENT_SPELL_CAST_CHANGED' then
|
Nenue@93
|
144 self:Refresh(event)
|
Nenue@93
|
145 elseif event == 'ARTIFACT_UPDATE' then
|
Nenue@93
|
146 self:UpdateArtifactPower()
|
Nenue@93
|
147 elseif event == 'MODIFIER_STATE_CHANGED' then
|
Nenue@93
|
148 self:UpdateModifierState()
|
Nenue@93
|
149 elseif event == 'SUPER_TRACKED_QUEST_CHANGED' then
|
Nenue@93
|
150 if superTrackedQuestID and db.QuestsByID[superTrackedQuestID] then
|
Nenue@93
|
151 db.QuestsByID[superTrackedQuestID].isStale = true
|
Nenue@93
|
152 end
|
Nenue@93
|
153 local newID = GetSuperTrackedQuestID()
|
Nenue@93
|
154 if newID and db.QuestsByID[newID] then
|
Nenue@93
|
155 db.QuestsByID[newID].isStale = true
|
Nenue@93
|
156 end
|
Nenue@93
|
157 elseif event == 'UNIT_SPELLCAST_STOP' then
|
Nenue@93
|
158 local name, _, _, _, spellID = ...
|
Nenue@93
|
159 if artifactKnowldegeSpells[spellID] then
|
Nenue@93
|
160 db.log('AK spellcast ended ' .. tostring(name) .. ' ('.. tostring(spellID)..')')
|
Nenue@93
|
161 self:UpdateArtifactPower()
|
Nenue@93
|
162 end
|
Nenue@93
|
163 end
|
Nenue@93
|
164 end
|
Nenue@93
|
165
|
Nenue@93
|
166 function Module:OnUpdate(sinceLast)
|
Nenue@93
|
167 if WorldPlanData.DebugEnabled then
|
Nenue@93
|
168 if self.refreshBenchMarkTicker then
|
Nenue@93
|
169 --print(self.refreshBenchMarkTicker)
|
Nenue@93
|
170 self.refreshBenchMarkTicker = self.refreshBenchMarkTicker - 1
|
Nenue@93
|
171
|
Nenue@93
|
172 if self.refreshBenchMarkTicker == 0 then
|
Nenue@93
|
173
|
Nenue@93
|
174 self.refreshTime = floor((GetTime() - self.refreshBenchMark) * 1000)
|
Nenue@93
|
175 self.debugMessage:SetText(self.refreshTime)
|
Nenue@93
|
176 self.refreshBenchMarkTicker = nil
|
Nenue@69
|
177 end
|
Nenue@69
|
178 else
|
Nenue@93
|
179 self.refreshBenchMark = GetTime()
|
Nenue@69
|
180 end
|
Nenue@69
|
181 end
|
Nenue@65
|
182
|
Nenue@93
|
183 if self.filtersDirty or self.isStale then
|
Nenue@93
|
184 self:Refresh()
|
Nenue@67
|
185 end
|
Nenue@72
|
186
|
Nenue@93
|
187 if #db.UpdatedPins >= 1 then
|
Nenue@93
|
188 --print('|cFF00FF88pending update', #db.UpdatedPins)
|
Nenue@93
|
189 self:UpdateNext()
|
Nenue@93
|
190 end
|
Nenue@93
|
191 end
|
Nenue@72
|
192
|
Nenue@93
|
193 local callbacks = {}
|
Nenue@69
|
194 callbacks.ClickWorldMapActionButton = function(WorldQuests)
|
Nenue@73
|
195 WorldQuests:Refresh('CLICK_MAP_ACTION_BUTTON')
|
Nenue@69
|
196 end
|
Nenue@69
|
197 callbacks.WorldMap_UpdateQuestBonusObjectives = function(WorldQuests)
|
Nenue@73
|
198 WorldQuests:UpdateTaskPOIs()
|
Nenue@69
|
199 end
|
Nenue@69
|
200 callbacks.WorldMapFrame_UpdateMap = function(WorldQuests)
|
Nenue@75
|
201 WorldQuests:RefreshIfChanged('WMF_UPDATE')
|
Nenue@69
|
202 end
|
Nenue@69
|
203 callbacks.WorldMapScrollFrame_ReanchorQuestPOIs = function (WorldQuests)
|
Nenue@75
|
204 WorldQuests:RefreshIfChanged('WMF_REANCHOR')
|
Nenue@69
|
205 end
|
Nenue@69
|
206
|
Nenue@72
|
207 callbacks[BountyBoard] = {}
|
Nenue@72
|
208 callbacks[BountyBoard].SetSelectedBountyIndex = function(WorldQuests)
|
Nenue@72
|
209 WorldQuests:UpdateBounties('BOUNTY_SELECTED')
|
Nenue@100
|
210 for questID, pin in pairs(db.QuestsByID) do
|
Nenue@100
|
211 pin.checkCriteria = true
|
Nenue@100
|
212 pin:Refresh()
|
Nenue@100
|
213 end
|
Nenue@72
|
214 end
|
Nenue@67
|
215
|
Nenue@72
|
216 callbacks[ActionButton] = {}
|
Nenue@72
|
217 callbacks[ActionButton].UpdateCastingState = function(WorldQuests)
|
Nenue@100
|
218 for questID, pin in pairs(db.QuestsByID) do
|
Nenue@100
|
219 pin.checkCursor = true
|
Nenue@100
|
220 pin:Refresh()
|
Nenue@100
|
221 end
|
Nenue@67
|
222 end
|
Nenue@67
|
223
|
Nenue@96
|
224 callbacks.UseWorldMapActionButtonSpellOnQuest = function(questID)
|
Nenue@97
|
225 local pin = db.QuestsByID[questID]
|
Nenue@97
|
226 -- calling this implies that the pin is used in some way
|
Nenue@97
|
227 if pin then
|
Nenue@100
|
228 db.log(pin.title .. ' completed by spell?', IsQuestComplete(pin.questID))
|
Nenue@100
|
229 pin:OnFilters()
|
Nenue@98
|
230 pin.isStale = true
|
Nenue@93
|
231 end
|
Nenue@96
|
232 end
|
Nenue@96
|
233
|
Nenue@96
|
234 function Module:SetupCallbacks()
|
Nenue@96
|
235 if InCombatLockdown() then
|
Nenue@97
|
236 return true
|
Nenue@96
|
237 end
|
Nenue@96
|
238 print('SetupCallbacks()')
|
Nenue@93
|
239 for target, arg in pairs(callbacks) do
|
Nenue@93
|
240 --print(type(target))
|
Nenue@93
|
241 if type(target) == 'table' then
|
Nenue@93
|
242 local callerName = target:GetName() or tostring(target)
|
Nenue@93
|
243 for name, method in pairs(arg) do
|
Nenue@93
|
244 --print(callerName, arg)
|
Nenue@93
|
245 hooksecurefunc(target, name, function(...)
|
Nenue@93
|
246 self:OnSecureHook(callerName .. '.' .. name, method, ...)
|
Nenue@93
|
247 end)
|
Nenue@93
|
248 end
|
Nenue@93
|
249 else
|
Nenue@93
|
250 hooksecurefunc(target, function(...)
|
Nenue@93
|
251 self:OnSecureHook(target, arg, ...)
|
Nenue@93
|
252 end)
|
Nenue@93
|
253 end
|
Nenue@93
|
254 end
|
Nenue@96
|
255 end
|
Nenue@96
|
256
|
Nenue@96
|
257 function Module:Setup()
|
Nenue@96
|
258 --print('|cFFFF4400'..self:GetName()..':Setup()')
|
Nenue@96
|
259 for mapID, mapName in pairs(WORLD_QUEST_MAPS) do
|
Nenue@96
|
260 db.QuestsByZone[mapID] = {}
|
Nenue@96
|
261 end
|
Nenue@96
|
262
|
Nenue@96
|
263 hooksDirty = self:SetupCallbacks()
|
Nenue@96
|
264
|
Nenue@93
|
265 self:SetAllPoints(WorldMapFrame.UIElementsFrame)
|
Nenue@93
|
266 self:UpdateArtifactPower()
|
Nenue@93
|
267 self:UpdateBounties('SETUP')
|
Nenue@93
|
268 self:Show()
|
Nenue@93
|
269 end
|
Nenue@93
|
270
|
Nenue@93
|
271 function Module:OnMapInfo(isBrokenIsle, isZoomedOut, mapAreaID, isNewMap, isMapOpen)
|
Nenue@93
|
272 if isNewMap or self.isStale then
|
Nenue@93
|
273 print('|cFF0088FFOnMapInfo()|r, mapAreaID =', mapAreaID,'visible =', isMapOpen, 'changed =', isNewMap)
|
Nenue@93
|
274 layoutDirty = true
|
Nenue@93
|
275 self:Refresh('WORLD_MAP_CHANGED')
|
Nenue@93
|
276 end
|
Nenue@93
|
277 end
|
Nenue@93
|
278
|
Nenue@49
|
279 function Module:OnConfigUpdate()
|
Nenue@75
|
280 --print('|cFFFFFF00OnConfigUpdate()|r')
|
Nenue@49
|
281 if db.Config.FadeWhileGrouped then
|
Nenue@49
|
282 db.PinAlpha = 0.15
|
Nenue@49
|
283 else
|
Nenue@49
|
284 db.PinAlpha = 1
|
Nenue@49
|
285 end
|
Nenue@67
|
286
|
Nenue@67
|
287 if not db.Config.EnablePins then
|
Nenue@67
|
288 for _, pin in pairs(db.QuestsByID) do
|
Nenue@67
|
289 pin:SetShown(false)
|
Nenue@67
|
290 end
|
Nenue@67
|
291 end
|
Nenue@45
|
292 end
|
Nenue@33
|
293
|
Nenue@69
|
294 function Module:OnSecureHook(callbackName, func, ...)
|
Nenue@98
|
295 print('|cFFFF4400'..callbackName..'|r', ...)
|
Nenue@69
|
296 func(self, ...)
|
Nenue@45
|
297 end
|
Nenue@40
|
298
|
Nenue@93
|
299 function Module:UpdateModifierState()
|
Nenue@33
|
300
|
Nenue@33
|
301 end
|
Nenue@33
|
302
|
Nenue@93
|
303 function Module:UpdateTaskPOIs()
|
Nenue@93
|
304 canTargetQuests = SpellCanTargetQuest()
|
Nenue@93
|
305 for i = 1, NUM_WORLDMAP_TASK_POIS do
|
Nenue@93
|
306 local poiFrame = _G['WorldMapFrameTaskPOI'..i]
|
Nenue@93
|
307 if poiFrame and poiFrame.worldQuest then
|
Nenue@93
|
308 local pin = db.QuestsByID[poiFrame.questID]
|
Nenue@93
|
309 if pin and pin.used and canTargetQuests and IsQuestIDValidSpellTarget(pin.questID) then
|
Nenue@93
|
310 poiFrame:Show()
|
Nenue@93
|
311 else
|
Nenue@93
|
312 poiFrame:Hide()
|
Nenue@93
|
313 end
|
Nenue@93
|
314 end
|
Nenue@93
|
315 end
|
Nenue@93
|
316 end
|
Nenue@93
|
317 -- re-anchors and scales pins that have had either of these changed due to data loading delays
|
Nenue@93
|
318 function Module:UpdateNext()
|
Nenue@93
|
319 --print('|cFF00FF88UpdateNext()')
|
Nenue@93
|
320 local pin = tremove(db.UpdatedPins)
|
Nenue@100
|
321 pin:OnFilters()
|
Nenue@40
|
322
|
Nenue@93
|
323 local scaleFactor = SCALE_FACTORS[(pin.dataLoaded and not pin.filtered) and scaleConstant or 1]
|
Nenue@93
|
324 --print(pin.title, pin.dataLoaded and not pin.filtered, scaleFactor)
|
Nenue@93
|
325 if pin.used then
|
Nenue@96
|
326 pin:SetShown(true)
|
Nenue@93
|
327 pin:SetAnchor(nil, pin.x, pin.y, self.hostWidth, self.hostHeight, scaleFactor)
|
Nenue@96
|
328 pin:Refresh()
|
Nenue@96
|
329 else
|
Nenue@96
|
330 print('|cFFFF4400flagging queued pin that got hidden:', pin.title)
|
Nenue@96
|
331 pin.isStale = true
|
Nenue@33
|
332 end
|
Nenue@33
|
333 end
|
Nenue@33
|
334
|
Nenue@72
|
335 function Module:UpdateBounties(...)
|
Nenue@103
|
336 bountiesDirty = nil
|
Nenue@103
|
337 print('|cFF00FF88BountyInfo()|r', ...)
|
Nenue@72
|
338 wipe(db.BountiesByFactionID)
|
Nenue@75
|
339 wipe(db.BountiesByQuestID)
|
Nenue@72
|
340
|
Nenue@72
|
341 db.selectedBounty = nil
|
Nenue@72
|
342 selectedBountyIndex = BountyBoard:GetSelectedBountyIndex()
|
Nenue@75
|
343 db.Bounties, bountyDisplayLocation, bountyLockedQuestID = GetQuestBountyInfoForMapID(db.currentMapID, db.Bounties)
|
Nenue@72
|
344 local numBounties = 0
|
Nenue@75
|
345 for index, info in ipairs(db.Bounties) do
|
Nenue@72
|
346 numBounties = numBounties + 1
|
Nenue@73
|
347 info.index = index
|
Nenue@73
|
348 info.complete = IsQuestComplete(info.questID)
|
Nenue@73
|
349 if not info.complete then
|
Nenue@73
|
350 db.BountiesByFactionID[info.factionID] = info
|
Nenue@75
|
351 db.BountiesByQuestID[info.questID] = info
|
Nenue@72
|
352 if index == selectedBountyIndex then
|
Nenue@73
|
353 db.selectedBounty = info
|
Nenue@73
|
354 selectedBountyQuestID = info.questID
|
Nenue@72
|
355 end
|
Nenue@73
|
356 print(' ', index, info.factionID, GetQuestLogTitle(GetQuestLogIndexByID(info.questID)), info.complete, (index == selectedBountyIndex) and 'SELECTED' or '')
|
Nenue@72
|
357 end
|
Nenue@72
|
358 end
|
Nenue@72
|
359 end
|
Nenue@72
|
360
|
Nenue@93
|
361 -- check current artifact knowledge and update pins accordingly
|
Nenue@93
|
362 function Module:UpdateArtifactPower(overrideLevel)
|
Nenue@93
|
363 if InCombatLockdown() then
|
Nenue@93
|
364 artifactPowerDirty = true
|
Nenue@93
|
365 return
|
Nenue@40
|
366 end
|
Nenue@40
|
367
|
Nenue@93
|
368 print('|cFF00FF88UpdateArtifactPower()|r')
|
Nenue@93
|
369 local _, akLevel = GetCurrencyInfo(1171)
|
Nenue@93
|
370 if overrideLevel then
|
Nenue@93
|
371 akLevel = overrideLevel
|
Nenue@40
|
372 end
|
Nenue@40
|
373
|
Nenue@93
|
374 --db.print('current AK', akLevel)
|
Nenue@93
|
375 if akLevel and (akLevel ~= artifactKnowledgeLevel) or (not artifactKnowledgeLevel) then
|
Nenue@93
|
376 --print('new ak level', akLevel)
|
Nenue@93
|
377 db.log('AK update ' .. tostring(artifactKnowledgeLevel) .. ' to '.. tostring(akLevel))
|
Nenue@93
|
378 for _, pin in pairs(db.QuestsByID) do
|
Nenue@93
|
379 if (pin.rewardType == REWARD_ARTIFACT_POWER) then
|
Nenue@93
|
380 print(pin.title, pin.itemNumber)
|
Nenue@93
|
381 local newAP = pin:UpdateArtifactPower()
|
Nenue@93
|
382 if newAP then
|
Nenue@93
|
383 pin.itemNumber = newAP
|
Nenue@93
|
384 print(newAP)
|
Nenue@93
|
385 else
|
Nenue@93
|
386 pin.dataLoaded = nil
|
Nenue@93
|
387 end
|
Nenue@93
|
388 pin.isStale = true
|
Nenue@93
|
389 end
|
Nenue@33
|
390 end
|
Nenue@93
|
391 artifactKnowledgeLevel = akLevel
|
Nenue@40
|
392 end
|
Nenue@93
|
393 artifactPowerDirty = nil
|
Nenue@75
|
394 end
|
Nenue@40
|
395
|
Nenue@72
|
396 local msg = '|cFF00FF88WorldQuests:Refresh()|r|cFF00FFFF'
|
Nenue@72
|
397 function Module:Refresh(...)
|
Nenue@96
|
398
|
Nenue@96
|
399 if hooksDirty then
|
Nenue@96
|
400 hooksDirty = self:SetupCallbacks()
|
Nenue@96
|
401 end
|
Nenue@96
|
402
|
Nenue@96
|
403
|
Nenue@34
|
404 if not self:IsVisible() then
|
Nenue@75
|
405 print('|cFFFF4400Refresh()|r', ...)
|
Nenue@75
|
406 return
|
Nenue@73
|
407 else
|
Nenue@75
|
408 if lastRefresh == GetTime() then
|
Nenue@75
|
409 print('|cFFFF4400multiple refreshes tried')
|
Nenue@75
|
410 end
|
Nenue@75
|
411 lastRefresh = GetTime()
|
Nenue@75
|
412 print(msg, lastRefresh, ...)
|
Nenue@40
|
413 end
|
Nenue@73
|
414
|
Nenue@103
|
415
|
Nenue@103
|
416 if bountiesDirty then
|
Nenue@103
|
417 self:UpdateBounties()
|
Nenue@103
|
418 end
|
Nenue@103
|
419
|
Nenue@67
|
420 if not db.Config.EnablePins then
|
Nenue@69
|
421 numShown = 0
|
Nenue@76
|
422 self.refreshBenchMark = GetTime()
|
Nenue@76
|
423 self.refreshBenchMarkTicker = 2
|
Nenue@76
|
424 print('starting bench', self.refreshBenchMark)
|
Nenue@67
|
425 return
|
Nenue@67
|
426 end
|
Nenue@67
|
427
|
Nenue@72
|
428 scaleConstant = db.isContinentMap and 2 or 3
|
Nenue@72
|
429 canTargetQuests = SpellCanTargetQuest()
|
Nenue@67
|
430
|
Nenue@40
|
431 for index, pin in pairs(db.QuestsByID) do
|
Nenue@40
|
432 pin.used = nil
|
Nenue@40
|
433 end
|
Nenue@40
|
434
|
Nenue@95
|
435 self:UpdateAnchors(...)
|
Nenue@72
|
436
|
Nenue@93
|
437 if artifactPowerDirty and not InCombatLockdown() then
|
Nenue@93
|
438 self:UpdateArtifactPower()
|
Nenue@93
|
439 end
|
Nenue@69
|
440 -- calculate quests shown
|
Nenue@65
|
441 numShown = 0
|
Nenue@65
|
442 numLoaded = 0
|
Nick@60
|
443 for questID, pin in pairs(db.QuestsByID) do
|
Nick@60
|
444 local oV = pin:IsShown()
|
Nick@60
|
445 if pin.used then
|
Nenue@96
|
446 print('show', pin.title)
|
Nick@60
|
447 pin.throttle = 1
|
Nick@60
|
448 pin:SetShown(true)
|
Nenue@65
|
449 numShown = numShown + 1
|
Nenue@65
|
450 if pin.dataLoaded then
|
Nenue@65
|
451 numLoaded = numLoaded + 1
|
Nenue@65
|
452 end
|
Nenue@65
|
453
|
Nenue@100
|
454 pin.checkCriteria = true
|
Nenue@100
|
455 pin.checkFilters = true
|
Nenue@100
|
456 pin:Refresh('WORLDMAP_REFRESH ' .. GetTime())
|
Nenue@100
|
457
|
Nick@60
|
458 else
|
Nenue@96
|
459 if pin:IsShown() then
|
Nenue@96
|
460 print('|cFFFF4400need to remove', pin.title)
|
Nenue@96
|
461
|
Nick@60
|
462 end
|
Nenue@96
|
463
|
Nenue@69
|
464 pin.hideReason = "Not used in map area " .. (db.currentMapID)
|
Nenue@75
|
465 pin:SetShown(false)
|
Nick@60
|
466 end
|
Nenue@93
|
467
|
Nick@60
|
468 end
|
Nenue@93
|
469
|
Nenue@65
|
470
|
Nenue@75
|
471 --
|
Nenue@93
|
472 self.refreshBenchMark = GetTime()
|
Nenue@93
|
473 self.refreshBenchMarkTicker = 2
|
Nenue@93
|
474 print('starting bench', self.refreshBenchMark)
|
Nenue@76
|
475
|
Nenue@75
|
476 --
|
Nenue@65
|
477
|
Nenue@73
|
478 layoutDirty = nil
|
Nenue@40
|
479 self.isStale = nil
|
Nenue@54
|
480 self.sizesDirty = nil
|
Nenue@66
|
481 self.isZoomDirty = nil
|
Nenue@75
|
482
|
Nenue@93
|
483 if WorldPlanSummary then
|
Nenue@93
|
484 WorldPlanSummary.isStale = true
|
Nenue@93
|
485 end
|
Nenue@93
|
486
|
Nenue@40
|
487 end
|
Nenue@40
|
488
|
Nenue@75
|
489 function Module:RefreshIfChanged(event)
|
Nenue@69
|
490 local scaleCheck = WorldMapDetailFrame:GetScale()
|
Nenue@73
|
491 refreshReason = nil
|
Nenue@69
|
492 if scaleCheck ~= currentScale then
|
Nenue@73
|
493 refreshReason = 'map scale updated'
|
Nenue@69
|
494 currentScale = scaleCheck
|
Nenue@75
|
495 layoutDirty = true
|
Nenue@72
|
496 elseif self.isStale or layoutDirty then
|
Nenue@73
|
497 refreshReason = 'layout is marked dirty'
|
Nenue@73
|
498 end
|
Nenue@73
|
499 if not refreshReason then
|
Nenue@73
|
500 return
|
Nenue@73
|
501 end
|
Nenue@73
|
502
|
Nenue@73
|
503 if self:IsVisible() then
|
Nenue@73
|
504 print('|cFF00FFFFRefreshIfChanged()|r', refreshReason)
|
Nenue@75
|
505 self:Refresh(event)
|
Nenue@73
|
506 else
|
Nenue@75
|
507 print('|cFF00FFFFRefreshIfChanged()|r', refreshReason)
|
Nenue@73
|
508 self.isStale = true
|
Nenue@69
|
509 end
|
Nenue@69
|
510 end
|
Nenue@69
|
511
|
Nenue@93
|
512 -- Walks the current map tree and fires updates as needed
|
Nenue@95
|
513 function Module:UpdateAnchors (event)
|
Nenue@40
|
514 wipe(self.UsedPositions)
|
Nenue@74
|
515 local hostWidth, hostHeight = WorldMapPOIFrame:GetSize()
|
Nenue@74
|
516
|
Nenue@74
|
517 if (hostWidth ~= self.hostWidth) or (hostHeight ~= self.hostHeight) then
|
Nenue@74
|
518 self.hostWidth, self.hostHeight = hostWidth, hostHeight
|
Nenue@74
|
519 layoutDirty = true
|
Nenue@74
|
520 end
|
Nenue@74
|
521
|
Nenue@95
|
522 print('|cFF00FF00UpdateAnchors()', event)
|
Nenue@33
|
523 local mapFileName, textureHeight, textureWidth, isMicroDungeon, microDungeonMapName = GetMapInfo()
|
Nenue@33
|
524 if isMicroDungeon then
|
Nenue@33
|
525 return
|
Nenue@33
|
526 end
|
Nenue@69
|
527
|
Nenue@65
|
528 isDataLoaded = true
|
Nenue@67
|
529 local taskInfo = TQ_GetQuestsForPlayerByMapID(db.currentMapID)
|
Nenue@40
|
530 if taskInfo then
|
Nenue@69
|
531 self:UpdateQuestsForMap(taskInfo, db.currentMapID)
|
Nenue@33
|
532 end
|
Nenue@67
|
533 local numZones = MC_GetNumZones(db.currentMapID)
|
Nenue@33
|
534 if numZones then
|
Nenue@33
|
535 for i = 1, numZones do
|
Nenue@67
|
536 local mapAreaID = MC_GetZoneInfo(db.currentMapID, i)
|
Nenue@67
|
537 local taskInfo = TQ_GetQuestsForPlayerByMapID(mapAreaID, db.currentMapID)
|
Nenue@82
|
538
|
Nenue@82
|
539 db.QuestsByZone[mapAreaID] = db.QuestsByZone[mapAreaID] or {}
|
Nenue@82
|
540
|
Nenue@40
|
541 if taskInfo then
|
Nenue@69
|
542 self:UpdateQuestsForMap(taskInfo, mapAreaID)
|
Nenue@40
|
543 end
|
Nenue@33
|
544 end
|
Nenue@33
|
545 end
|
Nenue@33
|
546 end
|
Nenue@33
|
547
|
Nenue@96
|
548 -- Attempt to display the pins for quests in taskInfo
|
Nenue@93
|
549 function Module:UpdateQuestsForMap(taskInfo, mapID)
|
Nenue@93
|
550 print('|cFF00FF00UpdateQuestsForMap()|r', GetMapNameByID(mapID), GetMapNameByID(db.currentMapID), layoutDirty)
|
Nenue@93
|
551 if db.QuestsByZone[mapID] then
|
Nenue@93
|
552 wipe(db.QuestsByZone[mapID])
|
Nenue@93
|
553 elseif db.isBrokenIsle then
|
Nenue@93
|
554 continentScanned = true
|
Nenue@93
|
555 end
|
Nenue@96
|
556 print('layoutDirty =',layoutDirty)
|
Nenue@93
|
557
|
Nenue@93
|
558 for index, info in pairs(taskInfo) do
|
Nenue@93
|
559 local questID, x, y = info.questId, info.x, info.y
|
Nenue@93
|
560 local pin = self:AcquirePin(info)
|
Nenue@100
|
561 if pin then
|
Nenue@100
|
562 if pin.canShow then
|
Nenue@100
|
563 pin.used = true
|
Nenue@100
|
564 print('using', pin.title, (pin.owningFrame ~= WorldMapFrame))
|
Nenue@100
|
565 if layoutDirty or (pin.owningFrame ~= WorldMapFrame) then
|
Nenue@100
|
566 local scaleFactor = SCALE_FACTORS[(not pin.filtered and scaleConstant) or 1]
|
Nenue@100
|
567 pin.owningFrame = WorldMapFrame
|
Nenue@100
|
568 pin:SetAnchor(WorldMapPOIFrame, x, y, self.hostWidth, self.hostHeight, scaleFactor)
|
Nenue@93
|
569
|
Nenue@93
|
570 end
|
Nenue@100
|
571 if db.QuestsByZone[mapID] then
|
Nenue@100
|
572 db.QuestsByZone[mapID][questID] = pin
|
Nenue@100
|
573 end
|
Nenue@100
|
574 else
|
Nenue@100
|
575 print('|cFFFF4400discarding|r', pin.title)
|
Nenue@93
|
576 end
|
Nenue@93
|
577 end
|
Nenue@93
|
578 end
|
Nenue@67
|
579 end
|
Nenue@93
|
580
|
Nenue@93
|
581 -- locates or creates a corresponding pin frame for the provided TaskInfo data
|
Nenue@93
|
582 function Module:AcquirePin (info)
|
Nenue@93
|
583 local questID = info.questId
|
Nenue@93
|
584 if not (questID and QuestUtils_IsQuestWorldQuest(questID)) then
|
Nenue@93
|
585 return nil
|
Nenue@93
|
586 end
|
Nenue@103
|
587 local pin = db.QuestsByID[questID]
|
Nenue@103
|
588 -- check to avoid creating unnecessary frames
|
Nenue@103
|
589 if IsQuestComplete(questID) or completedQuests[questID] then
|
Nenue@103
|
590 completedQuests[questID] = true
|
Nenue@103
|
591 if pin then
|
Nenue@103
|
592 pin:Release()
|
Nenue@103
|
593 end
|
Nenue@100
|
594 return nil
|
Nenue@100
|
595 end
|
Nenue@100
|
596
|
Nenue@93
|
597 if not pin then
|
Nenue@93
|
598 local numFree = #db.FreePins
|
Nenue@93
|
599 if numFree >= 1 then
|
Nenue@93
|
600 pin = tremove(db.FreePins, numFree)
|
Nenue@100
|
601 print('|cFF00FF00Acquire()|r Re-using', pin:GetName())
|
Nenue@93
|
602 else
|
Nenue@93
|
603 totalPins = totalPins + 1
|
Nenue@93
|
604 local name = 'WorldPlanQuestMarker' .. numOverlays
|
Nenue@100
|
605 print('|cFF00FF00Acquire()|r Creating', name)
|
Nenue@93
|
606 pin = CreateFrame('Frame', name, WorldMapPOIFrame, 'WorldPlanQuestPin')
|
Nenue@93
|
607
|
Nenue@93
|
608 pin:SetID(totalPins)
|
Nenue@93
|
609 numOverlays = numOverlays + 1
|
Nenue@93
|
610 --pin.iconBorder:SetVertexColor(0,0,0,1)
|
Nenue@93
|
611 end
|
Nenue@93
|
612 pin.questID = questID
|
Nenue@93
|
613 pin.throttle = pin.updateRate
|
Nenue@93
|
614 pin.currentWidth = nil
|
Nenue@100
|
615
|
Nenue@93
|
616 db.QuestsByID[questID] = pin
|
Nenue@93
|
617 tinsert(db.UsedPins, pin)
|
Nenue@93
|
618 end
|
Nenue@93
|
619
|
Nenue@103
|
620 if info then
|
Nenue@93
|
621 pin.inProgress = info.inProgress
|
Nenue@93
|
622 pin.floor = info.floor
|
Nenue@93
|
623 pin.numObjectives = info.numObjectives or 0
|
Nenue@93
|
624 if info.x and info.y then
|
Nenue@93
|
625 if (info.x ~= pin.x) or (info.y ~= pin.y) then
|
Nenue@93
|
626 pin.isStale = true
|
Nenue@93
|
627 --rprint('|cFFFF4400SetCoords|r', info.x, info.y)
|
Nenue@93
|
628 end
|
Nenue@93
|
629 end
|
Nenue@93
|
630 end
|
Nenue@93
|
631
|
Nenue@93
|
632 pin.x = info.x or pin.x
|
Nenue@93
|
633 pin.y = info.y or pin.y
|
Nenue@93
|
634
|
Nenue@93
|
635 if not HaveQuestRewardData(questID) then
|
Nenue@93
|
636 TQ_RequestPreloadRewardData(questID);
|
Nenue@93
|
637 end
|
Nenue@93
|
638
|
Nenue@93
|
639 if (not pin.dataLoaded) then
|
Nenue@93
|
640 local dataLoaded = pin:GetData()
|
Nenue@93
|
641 if dataLoaded then
|
Nenue@93
|
642 WorldPlan.dataFlush = true
|
Nenue@93
|
643 else
|
Nenue@93
|
644 isDataLoaded = false
|
Nenue@93
|
645 end
|
Nenue@93
|
646 end
|
Nenue@93
|
647
|
Nenue@100
|
648 pin:OnFilters()
|
Nenue@93
|
649 pin.isActive = TQ_IsActive(questID)
|
Nenue@93
|
650 --rprint(pin:GetID(), pin.filtered, pin.used)
|
Nenue@93
|
651 return pin
|
Nenue@93
|
652 end
|
Nenue@93
|
653
|
Nenue@93
|
654 function Module:Debug(...)
|
Nenue@93
|
655 print(...)
|
Nenue@67
|
656 end |