Nenue@28
|
1 --- ${PACKAGE_NAME}
|
Nenue@28
|
2 -- @file-author@
|
Nenue@28
|
3 -- @project-revision@ @project-hash@
|
Nenue@28
|
4 -- @file-revision@ @file-hash@
|
Nenue@28
|
5 -- Created: 3/26/2016 1:51 AM
|
Nenue@28
|
6 local B, _G = select(2,...).frame, _G
|
Nenue@28
|
7 local pairs, setmetatable, type, tostring, band, format = _G.pairs, _G.setmetatable, _G.type, _G.tostring, bit.band, string.format
|
Nenue@28
|
8 local ipairs, tinsert, hooksecurefunc = _G.ipairs, _G.tinsert, _G.hooksecurefunc
|
Nenue@28
|
9 local PlaySoundFile, IsQuestTask, SortQuestWatches, GetCurrentMapAreaID, GetZoneText, GetMinimapZoneText = PlaySoundFile, IsQuestTask, SortQuestWatches, GetCurrentMapAreaID, GetZoneText, GetMinimapZoneText
|
Nenue@28
|
10 local QuestPOIUpdateIcons, GetCVar, IsPlayerInMicroDungeon, WorldMapFrame, GetCVarBool, SetMapToCurrentZone = QuestPOIUpdateIcons, GetCVar, IsPlayerInMicroDungeon, WorldMapFrame, GetCVarBool, SetMapToCurrentZone
|
Nenue@28
|
11 local AddAutoQuestPopUp = AddAutoQuestPopUp
|
Nenue@28
|
12 local T = B:RegisterModule("ObjectiveTracker", _G.VeneerObjectiveWrapper, 'BuffFrame')
|
Nenue@28
|
13 local print = B.print('Objectives')
|
Nenue@28
|
14 local ObjectiveTrackerFrame, VeneerObjectiveScroll, CreateFrame = _G.ObjectiveTrackerFrame, _G.VeneerObjectiveScroll, _G.CreateFrame
|
Nenue@28
|
15 local Wrapper = _G.VeneerObjectiveWrapper
|
Nenue@28
|
16 local Scroller = VeneerObjectiveWrapper.scrollArea
|
Nenue@28
|
17 local Scroll = _G.VeneerObjectiveScroll
|
Nenue@28
|
18 local unitLevel = UnitLevel('player')
|
Nenue@28
|
19
|
Nenue@28
|
20 --- Performance values
|
Nenue@28
|
21
|
Nenue@44
|
22 --- Done once per ui load
|
Nenue@44
|
23 local BlizzHooks = {
|
Nenue@44
|
24 'AcceptQuest',
|
Nenue@44
|
25 'AddQuestWatch',
|
Nenue@44
|
26 'RemoveQuestWatch',
|
Nenue@44
|
27 'AbandonQuest',
|
Nenue@44
|
28 'AcknowledgeAutoAcceptQuest',
|
Nenue@44
|
29 'AddAutoQuestPopUp',
|
Nenue@44
|
30 'RemoveAutoQuestPopUp',
|
Nenue@44
|
31 'AddTrackedAchievement',
|
Nenue@44
|
32 'RemoveTrackedAchievement',
|
Nenue@44
|
33 'SetSuperTrackedQuestID',
|
Nenue@44
|
34 'SelectQuestLogEntry',
|
Nenue@44
|
35 }
|
Nenue@44
|
36 local enabledOnly = {
|
Nenue@44
|
37 ['AddQuestWatch'] = true,
|
Nenue@44
|
38 }
|
Nenue@28
|
39
|
Nenue@28
|
40 --- These are the bitfields used by Blizzard_ObjectiveTracker to determine which segments get parsed.
|
Nenue@28
|
41 --- They are replicated here so that plugins can make use of any securehook args involving this info.
|
Nenue@28
|
42 local OBJECTIVE_TRACKER_UPDATE_MODULE_QUEST = OBJECTIVE_TRACKER_UPDATE_MODULE_QUEST -- 0x0100
|
Nenue@28
|
43 local OBJECTIVE_TRACKER_UPDATE_MODULE_AUTO_QUEST_POPUP = OBJECTIVE_TRACKER_UPDATE_MODULE_AUTO_QUEST_POPUP -- 0x0200
|
Nenue@28
|
44 local OBJECTIVE_TRACKER_UPDATE_MODULE_BONUS_OBJECTIVE = OBJECTIVE_TRACKER_UPDATE_MODULE_BONUS_OBJECTIVE -- 0x0400
|
Nenue@28
|
45 local OBJECTIVE_TRACKER_UPDATE_MODULE_SCENARIO = OBJECTIVE_TRACKER_UPDATE_MODULE_SCENARIO -- 0x0800
|
Nenue@28
|
46 local OBJECTIVE_TRACKER_UPDATE_MODULE_ACHIEVEMENT = OBJECTIVE_TRACKER_UPDATE_MODULE_ACHIEVEMENT -- 0x1000
|
Nenue@28
|
47
|
Nenue@28
|
48
|
Nenue@28
|
49 local OBJECTIVE_TRACKER_UPDATE_STATIC = OBJECTIVE_TRACKER_UPDATE_STATIC -- 0x0000
|
Nenue@28
|
50 local OBJECTIVE_TRACKER_UPDATE_ALL = OBJECTIVE_TRACKER_UPDATE_ALL -- 0xFFFF
|
Nenue@28
|
51 local OBJECTIVE_TRACKER_UPDATE_ID = OBJECTIVE_TRACKER_UPDATE_ID -- 0
|
Nenue@28
|
52
|
Nenue@28
|
53 local OBJECTIVE_TRACKER_UPDATE_QUEST = OBJECTIVE_TRACKER_UPDATE_QUEST -- 0x0001
|
Nenue@28
|
54 local OBJECTIVE_TRACKER_UPDATE_QUEST_ADDED = OBJECTIVE_TRACKER_UPDATE_QUEST_ADDED -- 0x0002
|
Nenue@28
|
55 local OBJECTIVE_TRACKER_UPDATE_TASK_ADDED = OBJECTIVE_TRACKER_UPDATE_TASK_ADDED -- 0x0004
|
Nenue@28
|
56 local OBJECTIVE_TRACKER_UPDATE_SCENARIO = OBJECTIVE_TRACKER_UPDATE_SCENARIO -- 0x0008
|
Nenue@28
|
57 local OBJECTIVE_TRACKER_UPDATE_SCENARIO_NEW_STAGE = OBJECTIVE_TRACKER_UPDATE_SCENARIO_NEW_STAGE -- 0x0010
|
Nenue@28
|
58 local OBJECTIVE_TRACKER_UPDATE_ACHIEVEMENT = OBJECTIVE_TRACKER_UPDATE_ACHIEVEMENT -- 0x0020
|
Nenue@28
|
59 local OBJECTIVE_TRACKER_UPDATE_ACHIEVEMENT_ADDED = OBJECTIVE_TRACKER_UPDATE_ACHIEVEMENT_ADDED -- 0x0040
|
Nenue@28
|
60 local OBJECTIVE_TRACKER_UPDATE_SCENARIO_BONUS_DELAYED = OBJECTIVE_TRACKER_UPDATE_SCENARIO_BONUS_DELAYED -- 0x0080
|
Nenue@28
|
61
|
Nenue@28
|
62 local OBJECTIVE_TRACKER_UPDATE_REASON = OBJECTIVE_TRACKER_UPDATE_ALL -- default
|
Nenue@28
|
63 --- Used to determine which trackers are listening for money events
|
Nenue@28
|
64
|
Nenue@28
|
65 T.strings = {}
|
Nenue@28
|
66 T.strings.CLICK_TO_ACCCEPT = 'Click to Accept'
|
Nenue@28
|
67 T.strings.CLICK_TO_COMPLETE = 'Click to complete'
|
Nenue@28
|
68 T.colors ={
|
Nenue@28
|
69 enable = true,
|
Nenue@28
|
70 }
|
Nenue@28
|
71
|
Nenue@28
|
72 T.watchMoneyReasons = 0
|
Nenue@28
|
73
|
Nenue@28
|
74 --- Baseline defaults table; values defined in the files that they pertain to
|
Nenue@28
|
75 T.defaults = {}
|
Nenue@28
|
76
|
Nenue@34
|
77
|
Nenue@28
|
78 --- Tracker display order
|
Nenue@28
|
79 T.orderedNames = {'Bonus', 'AutoQuest', 'Quest', 'Cheevs'}
|
Nenue@28
|
80
|
Nenue@28
|
81 --- ipairs() argument tables
|
Nenue@28
|
82 T.orderedHandlers = setmetatable({}, {__mode = "k"})
|
Nenue@28
|
83 T.orderedTrackers = setmetatable({}, {__mode = "k"})
|
Nenue@28
|
84 T.indexedTrackers = setmetatable({}, {__mode = "k"})
|
Nenue@28
|
85
|
Nenue@28
|
86 --- pairs() argument tables
|
Nenue@28
|
87 T.namedTrackers = setmetatable({}, {__mode = "k"})
|
Nenue@28
|
88
|
Nenue@28
|
89 local WRAPPER_ANCHOR_POINT = 'TOPRIGHT'
|
Nenue@28
|
90 local WRAPPER_OFFSET_X = 0
|
Nenue@28
|
91 local WRAPPER_OFFSET_Y = -200
|
Nenue@28
|
92 local WRAPPER_MAX_HEIGHT = 670
|
Nenue@28
|
93 local WRAPPER_WIDTH = 280
|
Nenue@28
|
94 local WRAPPER_HEADER_HEIGHT = 24
|
Nenue@28
|
95
|
Nenue@28
|
96 T.defaults.Wrapper = {
|
Nenue@28
|
97 AnchorPoint = WRAPPER_ANCHOR_POINT,
|
Nenue@28
|
98 OffsetX = WRAPPER_OFFSET_X,
|
Nenue@28
|
99 OffsetY = WRAPPER_OFFSET_Y,
|
Nenue@28
|
100 Height = WRAPPER_MAX_HEIGHT,
|
Nenue@28
|
101 Width = WRAPPER_WIDTH,
|
Nenue@28
|
102 HeaderHeight = WRAPPER_HEADER_HEIGHT,
|
Nenue@28
|
103 TextSpacing = 3,
|
Nenue@33
|
104 TextIndent = 4,
|
Nenue@28
|
105 TitleSpacing = 3,
|
Nenue@33
|
106 TitleIndent = 4,
|
Nenue@28
|
107 }
|
Nenue@28
|
108
|
Nenue@28
|
109
|
Nenue@28
|
110
|
Nenue@28
|
111 --- Tracker module definitions begin here; innards dealing with data retreival and output are defined further in
|
Nenue@28
|
112 T.DefaultHandler = {
|
Nenue@28
|
113 previousHeight = 0,
|
Nenue@28
|
114
|
Nenue@28
|
115 name = "temp",
|
Nenue@28
|
116 displayName = "temp",
|
Nenue@28
|
117 updateReasonModule = 0xFF00,
|
Nenue@28
|
118 updateReasonEvent = 0x00FF,
|
Nenue@28
|
119
|
Nenue@28
|
120 numWatched = 0, --- number of entries being handled
|
Nenue@28
|
121 numBlocks = 0, --- number of blocks created
|
Nenue@28
|
122 actualBlocks = 0, --- number of blocks in use
|
Nenue@34
|
123 Info = {}, --- stored watch list information, keyed by whatever unique ID is involved for that tracker
|
Nenue@34
|
124 Watched = {}, --- stores whether the given unique ID is tracked
|
Nenue@28
|
125
|
Nenue@34
|
126 freeBlocks = {}, --- blocks hidden due to list shrinkage
|
Nenue@34
|
127 usedBlocks = {}, --- block in use
|
Nenue@34
|
128 BlockInfo = {}, --- by block creation offset, used by framescript
|
Nenue@37
|
129 WatchList = {}, --- ordered manifest of watched items
|
Nenue@28
|
130
|
Nenue@34
|
131 --- Indexes
|
Nenue@37
|
132 InfoBlock = {}, --- by unique ID
|
Nenue@34
|
133 LogBlock = {}, --- by API log offset, used by GetBlock if possible
|
Nenue@34
|
134 WatchBlock = {}, --- block by internal offset, used in GetBlock scope
|
Nenue@34
|
135 WatchInfo = {}, --- info by internal offset, used in Update scope
|
Nenue@28
|
136 }
|
Nenue@28
|
137
|
Nenue@28
|
138 T.AutoQuest = {
|
Nenue@28
|
139 name = "AutoQuest",
|
Nenue@28
|
140 displayName = "Notice",
|
Nenue@28
|
141 updateReasonModule = OBJECTIVE_TRACKER_UPDATE_MODULE_QUEST,
|
Nenue@28
|
142 updateReasonEvents = OBJECTIVE_TRACKER_UPDATE_QUEST + OBJECTIVE_TRACKER_UPDATE_QUEST_ADDED,
|
Nenue@38
|
143 internalColor = '00FFFF',
|
Nenue@29
|
144 LogInfo = {},
|
Nenue@29
|
145 QuestBlock = {},
|
Nenue@28
|
146 }
|
Nenue@28
|
147 T.Quest = {
|
Nenue@28
|
148 name = "Quest",
|
Nenue@28
|
149 displayName = "Quests",
|
Nenue@28
|
150 updateReasonModule = OBJECTIVE_TRACKER_UPDATE_MODULE_QUEST,
|
Nenue@28
|
151 updateReasonEvents = OBJECTIVE_TRACKER_UPDATE_QUEST + OBJECTIVE_TRACKER_UPDATE_QUEST_ADDED,
|
Nenue@38
|
152 internalColor = '0088FF',
|
Nenue@28
|
153 itemButtons = {},
|
Nenue@28
|
154 freeButtons = {},
|
Nenue@29
|
155 LogInfo = {},
|
Nenue@29
|
156 QuestBlock = {},
|
Nenue@28
|
157 }
|
Nenue@28
|
158 T.Cheevs = {
|
Nenue@28
|
159 name = "Cheevs",
|
Nenue@28
|
160 displayName = "Achievements",
|
Nenue@37
|
161 schema = 'achievement',
|
Nenue@28
|
162 updateReasonModule = OBJECTIVE_TRACKER_UPDATE_MODULE_ACHIEVEMENT,
|
Nenue@28
|
163 updateReasonEvents = OBJECTIVE_TRACKER_UPDATE_ACHIEVEMENT +
|
Nenue@28
|
164 OBJECTIVE_TRACKER_UPDATE_ACHIEVEMENT_ADDED,
|
Nenue@38
|
165 internalColor = '00FF88',
|
Nenue@28
|
166 }
|
Nenue@28
|
167 T.Bonus = {
|
Nenue@28
|
168 name = "Bonus",
|
Nenue@28
|
169 displayName = "Bonus Objectives",
|
Nenue@28
|
170 updateReasonModule = OBJECTIVE_TRACKER_UPDATE_MODULE_BONUS_OBJECTIVE,
|
Nenue@29
|
171 updateReasonEvents = OBJECTIVE_TRACKER_UPDATE_QUEST + OBJECTIVE_TRACKER_UPDATE_TASK_ADDED,
|
Nenue@38
|
172 internalColor = '00FF00',
|
Nenue@29
|
173 QuestBlock = {},
|
Nenue@28
|
174 }
|
Nenue@28
|
175
|
Nenue@28
|
176 T.Scenario = {
|
Nenue@28
|
177 name = 'Scenario',
|
Nenue@28
|
178 displayName = 'Scenario Objectives',
|
Nenue@28
|
179 updateReasonModule = OBJECTIVE_TRACKER_UPDATE_MODULE_SCENARIO,
|
Nenue@38
|
180 updateReasonEvents = OBJECTIVE_TRACKER_UPDATE_SCENARIO_NEW_STAGE + OBJECTIVE_TRACKER_UPDATE_SCENARIO_BONUS_DELAYED,
|
Nenue@38
|
181 internalColor = '88FF00',
|
Nenue@28
|
182 }
|
Nenue@38
|
183 local lastLabel
|
Nenue@38
|
184 local Tracker_debug = function(handler, channel)
|
Nenue@38
|
185 local func = B.print(channel)
|
Nenue@38
|
186 local color = handler.internalColor
|
Nenue@38
|
187 return function(label, ...)
|
Nenue@38
|
188 if lastLabel == label then
|
Nenue@38
|
189 label = label:gsub('%a', ' ').. ' '
|
Nenue@38
|
190 else
|
Nenue@38
|
191 lastLabel = label
|
Nenue@38
|
192 label = '|cFF'..color..label..':|r'
|
Nenue@38
|
193 end
|
Nenue@38
|
194 func(label, ...)
|
Nenue@38
|
195 end
|
Nenue@38
|
196 end
|
Nenue@28
|
197 local Tracker_string = function (self)
|
Nenue@28
|
198 return self.name
|
Nenue@28
|
199 end
|
Nenue@28
|
200 local Tracker_call = function (self, reason)
|
Nenue@28
|
201 self:Update(reason)
|
Nenue@28
|
202 end
|
Nenue@28
|
203 local Handler_Initialize = function (self, name, index)
|
Nenue@28
|
204 local c = T.Conf.Wrapper
|
Nenue@28
|
205 print('Initializing |cFF00FFFF'..name..'|r module...')
|
Nenue@28
|
206
|
Nenue@28
|
207 local handler = setmetatable(T[name] or {}, {
|
Nenue@28
|
208 __tostring = Tracker_string,
|
Nenue@28
|
209 __call = Tracker_call
|
Nenue@28
|
210 })
|
Nenue@28
|
211 if type(T.orderedHandlers[index]) == 'table' then
|
Nenue@28
|
212 return T.orderedHandlers[index]
|
Nenue@28
|
213 end
|
Nenue@28
|
214
|
Nenue@28
|
215 print('|cFFFFFF00Acquiring locals')
|
Nenue@28
|
216 local preset = {}
|
Nenue@28
|
217 for k, _ in pairs(handler) do
|
Nenue@28
|
218 preset[k] = true
|
Nenue@28
|
219 end
|
Nenue@28
|
220
|
Nenue@28
|
221
|
Nenue@28
|
222 print('|cFFFF8800Inheriting')
|
Nenue@28
|
223 for k, v in pairs(self) do
|
Nenue@28
|
224 if not handler[k] then
|
Nenue@28
|
225 if type(v) == 'table' then
|
Nenue@28
|
226 -- assume all tables to be local data; don't inherit or ref
|
Nenue@28
|
227 handler[k] = {}
|
Nenue@28
|
228 else
|
Nenue@28
|
229 handler[k] = self[k]
|
Nenue@28
|
230 end
|
Nenue@28
|
231 print('copying', k)
|
Nenue@28
|
232 end
|
Nenue@28
|
233 end
|
Nenue@28
|
234 print('|cFFFF4400'..tostring(name)..'|r:')
|
Nenue@28
|
235 for k, v in pairs(handler) do
|
Nenue@28
|
236 print(format("%32s %8s %s", (preset[k] and '|cFFFFFFFF' or '|cFFFFFF00') .. k .. '|r', type(v), tostring(v)))
|
Nenue@28
|
237 end
|
Nenue@28
|
238
|
Nenue@28
|
239 T[name] = handler
|
Nenue@28
|
240
|
Nenue@28
|
241 local trackerName = 'Veneer'..name..'Tracker'
|
Nenue@28
|
242 local handler = T[name]
|
Nenue@28
|
243 local frame = CreateFrame('Frame', trackerName, _G.VeneerObjectiveScroll, 'VeneerTrackerTemplate')
|
Nenue@28
|
244 frame.title:SetText(handler.displayName)
|
Nenue@28
|
245 frame:SetWidth(c.Width)
|
Nenue@30
|
246 frame.previousOffset = 0
|
Nenue@29
|
247
|
Nenue@28
|
248 handler.frame = frame
|
Nenue@29
|
249 handler.numBlocks = 0
|
Nenue@29
|
250 handler.actualBlocks = 0
|
Nenue@28
|
251 handler.trackerName = trackerName
|
Nenue@28
|
252 handler.lines = {}
|
Nenue@28
|
253 T.orderedTrackers[index] = frame
|
Nenue@28
|
254 T.namedTrackers[name] = frame
|
Nenue@28
|
255 T.indexedTrackers[handler] = frame
|
Nenue@28
|
256 print('|cFFFF0088' .. trackerName .. '|r created for |cFF00FFFF' .. handler.displayName .. '|r module')
|
Nenue@28
|
257
|
Nenue@38
|
258 handler.print = Tracker_debug(handler, 'Tracker')
|
Nenue@38
|
259 handler.lprint = Tracker_debug(handler, 'Line')
|
Nenue@38
|
260 handler.bprint = Tracker_debug(handler, 'Block')
|
Nenue@38
|
261
|
Nenue@28
|
262 T.orderedHandlers[index] = handler
|
Nenue@28
|
263 return true
|
Nenue@28
|
264 end
|
Nenue@28
|
265
|
Nenue@28
|
266 local Event = {}
|
Nenue@39
|
267
|
Nenue@28
|
268 Event.QUEST_LOG_UPDATE = function()
|
Nenue@39
|
269 return OBJECTIVE_TRACKER_UPDATE_QUEST
|
Nenue@28
|
270 end
|
Nenue@30
|
271 local GetNumQuestWatches, AddQuestWatch, SetSuperTrackedQuestID = GetNumQuestWatches, AddQuestWatch, SetSuperTrackedQuestID
|
Nenue@30
|
272 Event.QUEST_ACCEPTED = function(questLogIndex, questID, added)
|
Nenue@28
|
273 if ( IsQuestTask(questID) ) then
|
Nenue@38
|
274 return OBJECTIVE_TRACKER_UPDATE_QUEST_ADDED + OBJECTIVE_TRACKER_UPDATE_TASK_ADDED, questID, added
|
Nenue@28
|
275 else
|
Nenue@38
|
276 return OBJECTIVE_TRACKER_UPDATE_QUEST_ADDED, questID, added
|
Nenue@28
|
277 end
|
Nenue@38
|
278 AddQuestWatch(questID)
|
Nenue@28
|
279 end
|
Nenue@28
|
280
|
Nenue@28
|
281 Event.QUEST_WATCH_LIST_CHANGED = function(questID, added)
|
Nenue@37
|
282 if ( added == true ) then
|
Nenue@28
|
283 if ( not IsQuestTask(questID) ) then
|
Nenue@28
|
284 return OBJECTIVE_TRACKER_UPDATE_QUEST_ADDED, questID, added
|
Nenue@28
|
285 end
|
Nenue@37
|
286 elseif questID then
|
Nenue@37
|
287 return OBJECTIVE_TRACKER_UPDATE_QUEST_ADDED, questID, added
|
Nenue@38
|
288 else
|
Nenue@38
|
289 return OBJECTIVE_TRACKER_UPDATE_MODULE_QUEST
|
Nenue@28
|
290 end
|
Nenue@28
|
291 end
|
Nenue@28
|
292
|
Nenue@28
|
293 Event.QUEST_POI_UPDATE = function()
|
Nenue@28
|
294 QuestPOIUpdateIcons();
|
Nenue@28
|
295 if ( GetCVar("trackQuestSorting") == "proximity" ) then
|
Nenue@28
|
296 SortQuestWatches();
|
Nenue@28
|
297 end
|
Nenue@28
|
298 return OBJECTIVE_TRACKER_UPDATE_ALL
|
Nenue@28
|
299 end
|
Nenue@37
|
300 Event.SUPER_TRACKED_QUEST_CHANGED = function(questID)
|
Nenue@44
|
301 --return OBJECTIVE_TRACKER_UPDATE_QUEST, questID
|
Nenue@28
|
302 end
|
Nenue@28
|
303 Event.ZONE_CHANGED = function()
|
Nenue@28
|
304 local inMicroDungeon = IsPlayerInMicroDungeon();
|
Nenue@28
|
305 if ( inMicroDungeon ~= T.inMicroDungeon ) then
|
Nenue@28
|
306 if ( not WorldMapFrame:IsShown() and GetCVarBool("questPOI") ) then
|
Nenue@28
|
307 SetMapToCurrentZone(); -- update the zone to get the right POI numbers for the tracker
|
Nenue@28
|
308 end
|
Nenue@28
|
309 --SortQuestWatches();
|
Nenue@28
|
310 T.inMicroDungeon = inMicroDungeon;
|
Nenue@28
|
311 end
|
Nenue@33
|
312 return OBJECTIVE_TRACKER_UPDATE_MODULE_BONUS_OBJECTIVE + OBJECTIVE_TRACKER_UPDATE_MODULE_SCENARIO
|
Nenue@28
|
313 end
|
Nenue@28
|
314 Event.QUEST_AUTOCOMPLETE = function(questId)
|
Nenue@28
|
315 AddAutoQuestPopUp(questId, "COMPLETE");
|
Nenue@28
|
316 return OBJECTIVE_TRACKER_UPDATE_MODULE_QUEST + OBJECTIVE_TRACKER_UPDATE_MODULE_AUTO_QUEST_POPUP
|
Nenue@28
|
317 end
|
Nenue@28
|
318 Event.SCENARIO_CRITERIA_UPDATE = function()
|
Nenue@28
|
319 return OBJECTIVE_TRACKER_UPDATE_SCENARIO
|
Nenue@28
|
320 end
|
Nenue@28
|
321 Event.SCENARIO_UPDATE = function(newStage)
|
Nenue@28
|
322 if ( newStage ) then
|
Nenue@28
|
323 return OBJECTIVE_TRACKER_UPDATE_SCENARIO_NEW_STAGE
|
Nenue@28
|
324 else
|
Nenue@28
|
325 return OBJECTIVE_TRACKER_UPDATE_SCENARIO
|
Nenue@28
|
326 end
|
Nenue@28
|
327 end
|
Nenue@28
|
328 Event.TRACKED_ACHIEVEMENT_UPDATE = function()
|
Nenue@28
|
329 return OBJECTIVE_TRACKER_UPDATE_ACHIEVEMENT
|
Nenue@28
|
330 end
|
Nenue@28
|
331 Event.TRACKED_ACHIEVEMENT_LIST_CHANGED = function(achievementID, added)
|
Nenue@37
|
332 return OBJECTIVE_TRACKER_UPDATE_ACHIEVEMENT_ADDED, achievementID, added
|
Nenue@28
|
333 end
|
Nenue@28
|
334 Event.ZONE_CHANGED_NEW_AREA = function ()
|
Nenue@28
|
335 if ( not WorldMapFrame:IsShown() and GetCVarBool("questPOI") ) then
|
Nenue@28
|
336 SetMapToCurrentZone(); -- update the zone to get the right POI numbers for the tracker
|
Nenue@28
|
337 end
|
Nenue@28
|
338 SortQuestWatches();
|
Nenue@28
|
339 T.currentZoneArea = GetCurrentMapAreaID()
|
Nenue@28
|
340 print('Updating zone ID to', T.currentZoneArea, '=', GetZoneText(), GetMinimapZoneText())
|
Nenue@28
|
341
|
Nenue@28
|
342
|
Nenue@28
|
343 return OBJECTIVE_TRACKER_UPDATE_TASK_ADDED
|
Nenue@28
|
344 end
|
Nenue@28
|
345
|
Nenue@28
|
346
|
Nenue@28
|
347 Event.PLAYER_MONEY = function()
|
Nenue@28
|
348 if T.watchMoneyReasons > 0 then
|
Nenue@28
|
349 return T.watchMoneyReasons
|
Nenue@28
|
350 end
|
Nenue@28
|
351 end
|
Nenue@28
|
352 Event.CRITERIA_COMPLETE = function()
|
Nenue@28
|
353 return OBJECTIVE_TRACKER_UPDATE_MODULE_BONUS_OBJECTIVE
|
Nenue@28
|
354 end
|
Nenue@28
|
355 Event.QUEST_TURN_IN = function(questID, xp, money)
|
Nenue@28
|
356 if ( IsQuestTask(questID) ) then
|
Nenue@28
|
357 T.Bonus:OnTurnIn(questID, xp, money)
|
Nenue@28
|
358 print('updating bonus modules (code', OBJECTIVE_TRACKER_UPDATE_MODULE_BONUS_OBJECTIVE, ',', questID, xp, money)
|
Nenue@28
|
359 return OBJECTIVE_TRACKER_UPDATE_MODULE_BONUS_OBJECTIVE, questID, xp, money
|
Nenue@28
|
360 else
|
Nenue@28
|
361 return OBJECTIVE_TRACKER_UPDATE_MODULE_QUEST, questID, xp, money
|
Nenue@28
|
362 end
|
Nenue@28
|
363 end
|
Nenue@28
|
364 T.Event = Event
|
Nenue@28
|
365
|
Nenue@28
|
366 local VeneerData
|
Nenue@28
|
367
|
Nenue@28
|
368 T.SetWatchMoney = function(watchMoney, reason)
|
Nenue@28
|
369 if watchMoney then
|
Nenue@28
|
370 if band(T.watchMoneyReasons, reason) == 0 then
|
Nenue@28
|
371 T.watchMoneyReasons = T.watchMoneyReasons + reason;
|
Nenue@28
|
372 end
|
Nenue@28
|
373 else
|
Nenue@28
|
374 if band(T.watchMoneyReasons, reason) > 0 then
|
Nenue@28
|
375 T.watchMoneyReasons = T.watchMoneyReasons - reason;
|
Nenue@28
|
376 end
|
Nenue@28
|
377 end
|
Nenue@28
|
378 end
|
Nenue@28
|
379
|
Nenue@32
|
380 local iprint = B.print('Info')
|
Nenue@32
|
381 T.SetRewards = function(t, questID)
|
Nenue@34
|
382 local previousSelection = GetQuestLogSelection()
|
Nenue@32
|
383
|
Nenue@32
|
384 SelectQuestLogEntry(GetQuestLogIndexByID(questID))
|
Nenue@32
|
385 local numQuestChoices = GetNumQuestLogChoices();
|
Nenue@32
|
386 local skillName, skillIcon, skillPoints = GetQuestLogRewardSkillPoints();
|
Nenue@32
|
387 local xp = GetQuestLogRewardXP();
|
Nenue@32
|
388 local playerTitle = GetQuestLogRewardTitle();
|
Nenue@32
|
389 ProcessQuestLogRewardFactions();
|
Nenue@34
|
390
|
Nenue@32
|
391 local rewards = {}
|
Nenue@32
|
392 local texture, name, isTradeskillSpell, isSpellLearned, hideSpellLearnText, isBoostSpell, garrFollowerID = GetQuestLogRewardSpell(questID)
|
Nenue@32
|
393 if name then
|
Nenue@32
|
394 tinsert(rewards,{
|
Nenue@32
|
395 type = 'spell',
|
Nenue@32
|
396 name = name,
|
Nenue@32
|
397 texture = texture,
|
Nenue@32
|
398 })
|
Nenue@32
|
399 end
|
Nenue@39
|
400 if previousSelection then
|
Nenue@39
|
401 SelectQuestLogEntry(previousSelection)
|
Nenue@39
|
402 end
|
Nenue@32
|
403
|
Nenue@32
|
404 t.numCurrencies = GetNumQuestLogRewardCurrencies(questID)
|
Nenue@32
|
405 for i = 1, t.numCurrencies do
|
Nenue@32
|
406 local name, texture, count = GetQuestLogRewardCurrencyInfo(i, questID)
|
Nenue@32
|
407 tinsert(rewards,{
|
Nenue@32
|
408 type = 'currency',
|
Nenue@32
|
409 index = i,
|
Nenue@32
|
410 name = name,
|
Nenue@32
|
411 texture = texture,
|
Nenue@32
|
412 count = count
|
Nenue@32
|
413 });
|
Nenue@32
|
414 end
|
Nenue@32
|
415 -- items
|
Nenue@32
|
416 t.numItems = GetNumQuestLogRewards(questID)
|
Nenue@32
|
417 for i = 1, t.numItems do
|
Nenue@32
|
418 local name, texture, count, quality, isUsable = GetQuestLogRewardInfo(i, questID)
|
Nenue@32
|
419 tinsert(rewards, {
|
Nenue@32
|
420 type = 'item',
|
Nenue@32
|
421 index = i ,
|
Nenue@32
|
422 name = name,
|
Nenue@32
|
423 texture = texture,
|
Nenue@32
|
424 count = count,
|
Nenue@32
|
425 quality = quality,
|
Nenue@32
|
426 isUsable = isUsable
|
Nenue@32
|
427 });
|
Nenue@32
|
428 end
|
Nenue@32
|
429 -- money
|
Nenue@32
|
430
|
Nenue@32
|
431 local money = GetQuestLogRewardMoney(questID)
|
Nenue@32
|
432 if ( money > 0 ) then
|
Nenue@32
|
433 tinsert(rewards, {
|
Nenue@32
|
434 type = 'money',
|
Nenue@32
|
435 name = GetMoneyString(money),
|
Nenue@32
|
436 texture = "Interface\\Icons\\inv_misc_coin_01",
|
Nenue@32
|
437 count = 0,
|
Nenue@32
|
438 });
|
Nenue@32
|
439 end
|
Nenue@32
|
440
|
Nenue@32
|
441 if #rewards >= 1 then
|
Nenue@32
|
442 t.rewardInfo = rewards
|
Nenue@32
|
443 end
|
Nenue@32
|
444 end
|
Nenue@32
|
445
|
Nenue@28
|
446 local Play = function(file) if Devian and Devian.InWorkspace() then PlaySoundFile(file) end end
|
Nenue@28
|
447
|
Nenue@37
|
448 local tprint = B.print('Tracker')
|
Nenue@34
|
449 T.OnHookedFunc = function(name, ...)
|
Nenue@40
|
450 print('|cFFFF8800securehook:|r', name, '|cFF00FFFFargs:|r', ...)
|
Nenue@37
|
451 local updateReason, arg1, arg2, arg3 = T[name](...)
|
Nenue@34
|
452 if updateReason then
|
Nenue@37
|
453 print('|cFF00FFFFupdate reason:|r', updateReason, arg1, arg2, arg3)
|
Nenue@37
|
454 T:Update(updateReason, arg1, arg2, arg3)
|
Nenue@34
|
455 end
|
Nenue@34
|
456 end
|
Nenue@34
|
457
|
Nenue@28
|
458 function T:OnEvent (event, ...)
|
Nenue@28
|
459 local isHandled
|
Nenue@28
|
460 local reason, arg1, arg2, arg3
|
Nenue@28
|
461 if Event[event] then
|
Nenue@28
|
462 if type(Event[event]) == 'function' then
|
Nenue@28
|
463 Play([[Interface\Addons\SharedMedia_MyMedia\sound\Info.ogg]])
|
Nenue@28
|
464 reason, arg1, arg2, arg3 = Event[event](...)
|
Nenue@28
|
465 else
|
Nenue@37
|
466 Play([[Interface\Addons\SharedMedia_MyMedia\sound\Heart.ogg]])
|
Nenue@28
|
467 reason = Event[event]
|
Nenue@28
|
468 end
|
Nenue@28
|
469 else
|
Nenue@30
|
470 print('no event handler set for', event)
|
Nenue@30
|
471 Play([[Interface\Addons\SharedMedia_MyMedia\sound\IM.ogg]])
|
Nenue@28
|
472 end
|
Nenue@28
|
473 if reason then
|
Nenue@38
|
474 tprint('OnEvent(|cFF00FF00'.. event ..'|r):', ...)
|
Nenue@28
|
475 T:Update(reason, arg1, arg2, arg3)
|
Nenue@28
|
476 else
|
Nenue@40
|
477 print('OnEvent(|cFFFF4400'.. event ..'|r):', ...)
|
Nenue@40
|
478 print('no detected reason')
|
Nenue@40
|
479 --Play([[Interface\Addons\SharedMedia_MyMedia\sound\Quack.ogg]])
|
Nenue@28
|
480 end
|
Nenue@38
|
481 local args = (reason or '0')
|
Nenue@38
|
482 if arg1 then args = args .. ', ' .. tostring(arg1) end
|
Nenue@38
|
483 if arg2 then args = args .. ', ' .. tostring(arg2) end
|
Nenue@38
|
484 if arg3 then args = args .. ', ' .. tostring(arg3) end
|
Nenue@38
|
485 tprint('OnEvent(|cFF00FF00'.. event ..'|r):', ..., '|cFFFFFF00=> Update (|r', args,'|cFFFFFF00)|r')
|
Nenue@28
|
486
|
Nenue@28
|
487 end
|
Nenue@28
|
488
|
Nenue@28
|
489
|
Nenue@28
|
490 function T:OnInitialize()
|
Nenue@28
|
491 local c = T.Conf.Wrapper
|
Nenue@28
|
492 VeneerData = _G.VeneerData
|
Nenue@28
|
493 VeneerData.CallLog = VeneerData.CallLog or {}
|
Nenue@28
|
494 if not T.isHooked then
|
Nenue@28
|
495 T.isHooked = true
|
Nenue@44
|
496 for _, func in ipairs(BlizzHooks) do
|
Nenue@44
|
497 if T[func] then
|
Nenue@44
|
498 hooksecurefunc(func, function(...) return T.OnHookedFunc(func, ...) end)
|
Nenue@28
|
499 else
|
Nenue@44
|
500 hooksecurefunc(func, function(...)
|
Nenue@44
|
501 print('|cFFFF0088securehook('..tostring(func)..')|r args:', ...)
|
Nenue@44
|
502 tinsert(VeneerData.CallLog, {func, ...})
|
Nenue@28
|
503 end)
|
Nenue@28
|
504 end
|
Nenue@28
|
505 end
|
Nenue@28
|
506 end
|
Nenue@28
|
507
|
Nenue@40
|
508
|
Nenue@28
|
509
|
Nenue@28
|
510 ObjectiveTrackerFrame:UnregisterAllEvents()
|
Nenue@28
|
511 ObjectiveTrackerFrame:Hide()
|
Nenue@33
|
512 _G.MinimapCluster:Hide()
|
Nenue@28
|
513
|
Nenue@28
|
514 for id, name in ipairs(T.orderedNames) do
|
Nenue@28
|
515 if not T.orderedHandlers[id] then
|
Nenue@28
|
516 Handler_Initialize(T.DefaultHandler, name, id)
|
Nenue@28
|
517 end
|
Nenue@28
|
518 end
|
Nenue@28
|
519 self:SetSize(c.Width, 40)
|
Nenue@28
|
520 T.InitializeWidgets()
|
Nenue@28
|
521 end
|
Nenue@28
|
522
|
Nenue@28
|
523 --- Done any time the the minimize button is toggled up
|
Nenue@28
|
524 function T:OnEnable()
|
Nenue@28
|
525
|
Nenue@28
|
526 print(B.Conf.VeneerObjectiveWrapper.enabled)
|
Nenue@34
|
527
|
Nenue@28
|
528
|
Nenue@28
|
529 for event, action in pairs(Event) do
|
Nenue@28
|
530 print('|cFFFF0088listen to', event, 'for action|r', tostring(action))
|
Nenue@28
|
531 Wrapper:RegisterEvent(event)
|
Nenue@28
|
532 end
|
Nenue@28
|
533
|
Nenue@28
|
534 local c = T.Conf.Wrapper
|
Nenue@30
|
535 Wrapper.previousHeight = 0
|
Nenue@28
|
536 Scroller:SetScrollChild(Scroll)
|
Nenue@28
|
537 Scroller:SetWidth(c.Width)
|
Nenue@28
|
538 Scroll:SetWidth(c.Width)
|
Nenue@28
|
539 Scroll:ClearAllPoints()
|
Nenue@28
|
540 Scroll:SetPoint('TOP', Scroller, 'TOP')
|
Nenue@28
|
541 self:SetScript('OnEvent', T.OnEvent)
|
Nenue@28
|
542
|
Nenue@28
|
543 Scroller:Show()
|
Nenue@28
|
544
|
Nenue@28
|
545 local from, target, to, x, y = Wrapper:GetPoint(1)
|
Nenue@38
|
546 print(from, target, to, x,y)
|
Nenue@28
|
547
|
Nenue@28
|
548
|
Nenue@38
|
549 T.UpdateSchema('tracker', 'default')
|
Nenue@28
|
550 -- run once to prime the data structure
|
Nenue@28
|
551 T.UpdateActionButtons()
|
Nenue@28
|
552 end
|
Nenue@28
|
553
|
Nenue@28
|
554 function T:OnDisable()
|
Nenue@28
|
555 self:UnregisterAllEvents()
|
Nenue@28
|
556 Scroller:Hide()
|
Nenue@28
|
557 end
|
Nenue@28
|
558
|