annotate ObjectiveTracker/ObjectiveTracker.lua @ 28:c33c17dd97e7

file renames
author Nenue
date Wed, 13 Apr 2016 20:19:37 -0400
parents
children adcd7c328d07
rev   line source
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 AddQuestWatch, SetSuperTrackedQuestID, GetNumQuestWatches, AUTO_QUEST_WATCH, MAX_WATCHABLE_QUESTS = AddQuestWatch, SetSuperTrackedQuestID, GetNumQuestWatches, AUTO_QUEST_WATCH, MAX_WATCHABLE_QUESTS
Nenue@28 11 local QuestPOIUpdateIcons, GetCVar, IsPlayerInMicroDungeon, WorldMapFrame, GetCVarBool, SetMapToCurrentZone = QuestPOIUpdateIcons, GetCVar, IsPlayerInMicroDungeon, WorldMapFrame, GetCVarBool, SetMapToCurrentZone
Nenue@28 12 local AddAutoQuestPopUp = AddAutoQuestPopUp
Nenue@28 13 local T = B:RegisterModule("ObjectiveTracker", _G.VeneerObjectiveWrapper, 'BuffFrame')
Nenue@28 14 local print = B.print('Objectives')
Nenue@28 15 local ObjectiveTrackerFrame, VeneerObjectiveScroll, CreateFrame = _G.ObjectiveTrackerFrame, _G.VeneerObjectiveScroll, _G.CreateFrame
Nenue@28 16 local Wrapper = _G.VeneerObjectiveWrapper
Nenue@28 17 local Scroller = VeneerObjectiveWrapper.scrollArea
Nenue@28 18 local Scroll = _G.VeneerObjectiveScroll
Nenue@28 19 local unitLevel = UnitLevel('player')
Nenue@28 20
Nenue@28 21 --- Performance values
Nenue@28 22 --[[
Nenue@28 23 self:RegisterEvent("QUEST_LOG_UPDATE");
Nenue@28 24 self:RegisterEvent("TRACKED_ACHIEVEMENT_LIST_CHANGED");
Nenue@28 25 self:RegisterEvent("QUEST_WATCH_LIST_CHANGED");
Nenue@28 26 self:RegisterEvent("QUEST_AUTOCOMPLETE");
Nenue@28 27 self:RegisterEvent("QUEST_ACCEPTED");
Nenue@28 28 self:RegisterEvent("SUPER_TRACKED_QUEST_CHANGED");
Nenue@28 29 self:RegisterEvent("SCENARIO_UPDATE");
Nenue@28 30 self:RegisterEvent("SCENARIO_CRITERIA_UPDATE");
Nenue@28 31 self:RegisterEvent("TRACKED_ACHIEVEMENT_UPDATE");
Nenue@28 32 self:RegisterEvent("ZONE_CHANGED_NEW_AREA");
Nenue@28 33 self:RegisterEvent("ZONE_CHANGED");
Nenue@28 34 self:RegisterEvent("QUEST_POI_UPDATE");
Nenue@28 35 self:RegisterEvent("VARIABLES_LOADED");
Nenue@28 36 self:RegisterEvent("QUEST_TURNED_IN");
Nenue@28 37 self:RegisterEvent("PLAYER_MONEY");
Nenue@28 38 ]]
Nenue@28 39
Nenue@28 40
Nenue@28 41 --- These are the bitfields used by Blizzard_ObjectiveTracker to determine which segments get parsed.
Nenue@28 42 --- They are replicated here so that plugins can make use of any securehook args involving this info.
Nenue@28 43 local OBJECTIVE_TRACKER_UPDATE_MODULE_QUEST = OBJECTIVE_TRACKER_UPDATE_MODULE_QUEST -- 0x0100
Nenue@28 44 local OBJECTIVE_TRACKER_UPDATE_MODULE_AUTO_QUEST_POPUP = OBJECTIVE_TRACKER_UPDATE_MODULE_AUTO_QUEST_POPUP -- 0x0200
Nenue@28 45 local OBJECTIVE_TRACKER_UPDATE_MODULE_BONUS_OBJECTIVE = OBJECTIVE_TRACKER_UPDATE_MODULE_BONUS_OBJECTIVE -- 0x0400
Nenue@28 46 local OBJECTIVE_TRACKER_UPDATE_MODULE_SCENARIO = OBJECTIVE_TRACKER_UPDATE_MODULE_SCENARIO -- 0x0800
Nenue@28 47 local OBJECTIVE_TRACKER_UPDATE_MODULE_ACHIEVEMENT = OBJECTIVE_TRACKER_UPDATE_MODULE_ACHIEVEMENT -- 0x1000
Nenue@28 48
Nenue@28 49
Nenue@28 50 local OBJECTIVE_TRACKER_UPDATE_STATIC = OBJECTIVE_TRACKER_UPDATE_STATIC -- 0x0000
Nenue@28 51 local OBJECTIVE_TRACKER_UPDATE_ALL = OBJECTIVE_TRACKER_UPDATE_ALL -- 0xFFFF
Nenue@28 52 local OBJECTIVE_TRACKER_UPDATE_ID = OBJECTIVE_TRACKER_UPDATE_ID -- 0
Nenue@28 53
Nenue@28 54 local OBJECTIVE_TRACKER_UPDATE_QUEST = OBJECTIVE_TRACKER_UPDATE_QUEST -- 0x0001
Nenue@28 55 local OBJECTIVE_TRACKER_UPDATE_QUEST_ADDED = OBJECTIVE_TRACKER_UPDATE_QUEST_ADDED -- 0x0002
Nenue@28 56 local OBJECTIVE_TRACKER_UPDATE_TASK_ADDED = OBJECTIVE_TRACKER_UPDATE_TASK_ADDED -- 0x0004
Nenue@28 57 local OBJECTIVE_TRACKER_UPDATE_SCENARIO = OBJECTIVE_TRACKER_UPDATE_SCENARIO -- 0x0008
Nenue@28 58 local OBJECTIVE_TRACKER_UPDATE_SCENARIO_NEW_STAGE = OBJECTIVE_TRACKER_UPDATE_SCENARIO_NEW_STAGE -- 0x0010
Nenue@28 59 local OBJECTIVE_TRACKER_UPDATE_ACHIEVEMENT = OBJECTIVE_TRACKER_UPDATE_ACHIEVEMENT -- 0x0020
Nenue@28 60 local OBJECTIVE_TRACKER_UPDATE_ACHIEVEMENT_ADDED = OBJECTIVE_TRACKER_UPDATE_ACHIEVEMENT_ADDED -- 0x0040
Nenue@28 61 local OBJECTIVE_TRACKER_UPDATE_SCENARIO_BONUS_DELAYED = OBJECTIVE_TRACKER_UPDATE_SCENARIO_BONUS_DELAYED -- 0x0080
Nenue@28 62
Nenue@28 63 local OBJECTIVE_TRACKER_UPDATE_REASON = OBJECTIVE_TRACKER_UPDATE_ALL -- default
Nenue@28 64 --- Used to determine which trackers are listening for money events
Nenue@28 65
Nenue@28 66 T.strings = {}
Nenue@28 67 T.strings.CLICK_TO_ACCCEPT = 'Click to Accept'
Nenue@28 68 T.strings.CLICK_TO_COMPLETE = 'Click to complete'
Nenue@28 69 T.colors ={
Nenue@28 70 enable = true,
Nenue@28 71 default = {
Nenue@28 72 titlebg = {'HORIZONTAL', 1, 0, .7, .25, 1, 0, .7, .125},
Nenue@28 73 textbg = {'HORIZONTAL', 0, 0, 0, 0.4, 0, 0, 0, 0 },
Nenue@28 74 selectionbg = {'HORIZONTAL', 1, 1, 1, 0, 1, 1, 1, 0.225},
Nenue@28 75 },
Nenue@28 76 daily = {
Nenue@28 77 titlebg = {'HORIZONTAL', 0, .7, 1, .25, 0, 1, .7, .125},
Nenue@28 78 textbg = {'HORIZONTAL', 0, .7, 1, .1, 0, 1, .7, .075 },
Nenue@28 79 },
Nenue@28 80 weekly = {
Nenue@28 81 titlebg = {'HORIZONTAL', 0, .35, .7, .25, 0, .35, .7, .125},
Nenue@28 82 textbg = {'HORIZONTAL', 0, .35, .7, .1, 0, .35, .7, .075 },
Nenue@28 83 },
Nenue@28 84 account = {
Nenue@28 85 titlebg = {'HORIZONTAL', .1, .1, .1, .25, .1, .1, .1, .125},
Nenue@28 86 textbg = {'HORIZONTAL', .1, .1, .1, 0.4, .1, .1, .1, .085 },
Nenue@28 87 },
Nenue@28 88 -- alliance
Nenue@28 89 faction_1 = {
Nenue@28 90 titlebg = {'HORIZONTAL', .2, .4, 1, 0.4, .2, .4, 1, .085 },
Nenue@28 91 textbg = {'HORIZONTAL', .2, .4, 1, 0.4, .2, .4, 1, .085 },
Nenue@28 92 },
Nenue@28 93 -- horde
Nenue@28 94 faction_2 = {
Nenue@28 95 titlebg = {'HORIZONTAL', .6, 0, 0.4, 0.4, .6, 0, 0.4, .085 },
Nenue@28 96 textbg = {'HORIZONTAL', .6, 0, 0.4, 0.4, .6, 0, 0.4, .085 },
Nenue@28 97 }
Nenue@28 98 }
Nenue@28 99
Nenue@28 100 T.watchMoneyReasons = 0
Nenue@28 101
Nenue@28 102 --- Baseline defaults table; values defined in the files that they pertain to
Nenue@28 103 T.defaults = {}
Nenue@28 104
Nenue@28 105 --- Tracker display order
Nenue@28 106 T.orderedNames = {'Bonus', 'AutoQuest', 'Quest', 'Cheevs'}
Nenue@28 107
Nenue@28 108 --- ipairs() argument tables
Nenue@28 109 T.orderedHandlers = setmetatable({}, {__mode = "k"})
Nenue@28 110 T.orderedTrackers = setmetatable({}, {__mode = "k"})
Nenue@28 111 T.indexedTrackers = setmetatable({}, {__mode = "k"})
Nenue@28 112
Nenue@28 113 --- pairs() argument tables
Nenue@28 114 T.namedTrackers = setmetatable({}, {__mode = "k"})
Nenue@28 115
Nenue@28 116 local WRAPPER_ANCHOR_POINT = 'TOPRIGHT'
Nenue@28 117 local WRAPPER_OFFSET_X = 0
Nenue@28 118 local WRAPPER_OFFSET_Y = -200
Nenue@28 119 local WRAPPER_MAX_HEIGHT = 670
Nenue@28 120 local WRAPPER_WIDTH = 280
Nenue@28 121 local WRAPPER_HEADER_HEIGHT = 24
Nenue@28 122
Nenue@28 123 T.defaults.Wrapper = {
Nenue@28 124 AnchorPoint = WRAPPER_ANCHOR_POINT,
Nenue@28 125 OffsetX = WRAPPER_OFFSET_X,
Nenue@28 126 OffsetY = WRAPPER_OFFSET_Y,
Nenue@28 127 Height = WRAPPER_MAX_HEIGHT,
Nenue@28 128 Width = WRAPPER_WIDTH,
Nenue@28 129 HeaderHeight = WRAPPER_HEADER_HEIGHT,
Nenue@28 130 TextSpacing = 3,
Nenue@28 131 TitleSpacing = 3,
Nenue@28 132 }
Nenue@28 133
Nenue@28 134
Nenue@28 135
Nenue@28 136 --- Tracker module definitions begin here; innards dealing with data retreival and output are defined further in
Nenue@28 137 T.DefaultHandler = {
Nenue@28 138 previousHeight = 0,
Nenue@28 139
Nenue@28 140 name = "temp",
Nenue@28 141 displayName = "temp",
Nenue@28 142 updateReasonModule = 0xFF00,
Nenue@28 143 updateReasonEvent = 0x00FF,
Nenue@28 144
Nenue@28 145 numWatched = 0, --- number of entries being handled
Nenue@28 146 numBlocks = 0, --- number of blocks created
Nenue@28 147 actualBlocks = 0, --- number of blocks in use
Nenue@28 148
Nenue@28 149 freeBlocks = {}, --- block heap
Nenue@28 150 usedBlocks = {},
Nenue@28 151
Nenue@28 152 Info = {}, -- find data by ID
Nenue@28 153 BlockInfo = {}, -- find data by block ID
Nenue@28 154 Watched = {}, -- find watchIndex by data ID
Nenue@28 155 WatchInfo = {}, -- find data by watch index
Nenue@28 156 WatchBlock = {}, -- find block by watch index
Nenue@28 157 }
Nenue@28 158
Nenue@28 159 T.AutoQuest = {
Nenue@28 160 name = "AutoQuest",
Nenue@28 161 displayName = "Notice",
Nenue@28 162 updateReasonModule = OBJECTIVE_TRACKER_UPDATE_MODULE_QUEST,
Nenue@28 163 updateReasonEvents = OBJECTIVE_TRACKER_UPDATE_QUEST + OBJECTIVE_TRACKER_UPDATE_QUEST_ADDED,
Nenue@28 164 }
Nenue@28 165 T.Quest = {
Nenue@28 166 name = "Quest",
Nenue@28 167 displayName = "Quests",
Nenue@28 168 updateReasonModule = OBJECTIVE_TRACKER_UPDATE_MODULE_QUEST,
Nenue@28 169 updateReasonEvents = OBJECTIVE_TRACKER_UPDATE_QUEST + OBJECTIVE_TRACKER_UPDATE_QUEST_ADDED,
Nenue@28 170 itemButtons = {},
Nenue@28 171 freeButtons = {},
Nenue@28 172 }
Nenue@28 173 T.Cheevs = {
Nenue@28 174 name = "Cheevs",
Nenue@28 175 displayName = "Achievements",
Nenue@28 176 updateReasonModule = OBJECTIVE_TRACKER_UPDATE_MODULE_ACHIEVEMENT,
Nenue@28 177 updateReasonEvents = OBJECTIVE_TRACKER_UPDATE_ACHIEVEMENT +
Nenue@28 178 OBJECTIVE_TRACKER_UPDATE_ACHIEVEMENT_ADDED,
Nenue@28 179 }
Nenue@28 180 T.Bonus = {
Nenue@28 181 name = "Bonus",
Nenue@28 182 displayName = "Bonus Objectives",
Nenue@28 183 updateReasonModule = OBJECTIVE_TRACKER_UPDATE_MODULE_BONUS_OBJECTIVE,
Nenue@28 184 updateReasonEvents = OBJECTIVE_TRACKER_UPDATE_QUEST + OBJECTIVE_TRACKER_UPDATE_TASK_ADDED
Nenue@28 185 }
Nenue@28 186
Nenue@28 187 T.Scenario = {
Nenue@28 188 name = 'Scenario',
Nenue@28 189 displayName = 'Scenario Objectives',
Nenue@28 190 updateReasonModule = OBJECTIVE_TRACKER_UPDATE_MODULE_SCENARIO,
Nenue@28 191 updateReasonEvents = OBJECTIVE_TRACKER_UPDATE_SCENARIO_NEW_STAGE + OBJECTIVE_TRACKER_UPDATE_SCENARIO_BONUS_DELAYED
Nenue@28 192 }
Nenue@28 193
Nenue@28 194 local Tracker_string = function (self)
Nenue@28 195 return self.name
Nenue@28 196 end
Nenue@28 197 local Tracker_call = function (self, reason)
Nenue@28 198 self:Update(reason)
Nenue@28 199 end
Nenue@28 200 local Handler_Initialize = function (self, name, index)
Nenue@28 201 local c = T.Conf.Wrapper
Nenue@28 202 print('Initializing |cFF00FFFF'..name..'|r module...')
Nenue@28 203
Nenue@28 204 local handler = setmetatable(T[name] or {}, {
Nenue@28 205 __tostring = Tracker_string,
Nenue@28 206 __call = Tracker_call
Nenue@28 207 })
Nenue@28 208 if type(T.orderedHandlers[index]) == 'table' then
Nenue@28 209 return T.orderedHandlers[index]
Nenue@28 210 end
Nenue@28 211
Nenue@28 212 print('|cFFFFFF00Acquiring locals')
Nenue@28 213 local preset = {}
Nenue@28 214 for k, _ in pairs(handler) do
Nenue@28 215 preset[k] = true
Nenue@28 216 end
Nenue@28 217
Nenue@28 218
Nenue@28 219 print('|cFFFF8800Inheriting')
Nenue@28 220 for k, v in pairs(self) do
Nenue@28 221 if not handler[k] then
Nenue@28 222 if type(v) == 'table' then
Nenue@28 223 -- assume all tables to be local data; don't inherit or ref
Nenue@28 224 handler[k] = {}
Nenue@28 225 else
Nenue@28 226 handler[k] = self[k]
Nenue@28 227 end
Nenue@28 228 print('copying', k)
Nenue@28 229 end
Nenue@28 230 end
Nenue@28 231 print('|cFFFF4400'..tostring(name)..'|r:')
Nenue@28 232 for k, v in pairs(handler) do
Nenue@28 233 print(format("%32s %8s %s", (preset[k] and '|cFFFFFFFF' or '|cFFFFFF00') .. k .. '|r', type(v), tostring(v)))
Nenue@28 234 end
Nenue@28 235
Nenue@28 236 T[name] = handler
Nenue@28 237
Nenue@28 238 local trackerName = 'Veneer'..name..'Tracker'
Nenue@28 239 local handler = T[name]
Nenue@28 240 local frame = CreateFrame('Frame', trackerName, _G.VeneerObjectiveScroll, 'VeneerTrackerTemplate')
Nenue@28 241 frame.title:SetText(handler.displayName)
Nenue@28 242 frame:SetWidth(c.Width)
Nenue@28 243 handler.frame = frame
Nenue@28 244 handler.trackerName = trackerName
Nenue@28 245 handler.lines = {}
Nenue@28 246 T.orderedTrackers[index] = frame
Nenue@28 247 T.namedTrackers[name] = frame
Nenue@28 248 T.indexedTrackers[handler] = frame
Nenue@28 249 print('|cFFFF0088' .. trackerName .. '|r created for |cFF00FFFF' .. handler.displayName .. '|r module')
Nenue@28 250
Nenue@28 251 T.orderedHandlers[index] = handler
Nenue@28 252 return true
Nenue@28 253 end
Nenue@28 254
Nenue@28 255 local Event = {}
Nenue@28 256 Event.QUEST_LOG_UPDATE = function()
Nenue@28 257 return OBJECTIVE_TRACKER_UPDATE_MODULE_QUEST + OBJECTIVE_TRACKER_UPDATE_MODULE_BONUS_OBJECTIVE
Nenue@28 258 end
Nenue@28 259 Event.QUEST_ACCEPTED = function(questLogIndex, questID)
Nenue@28 260 if ( IsQuestTask(questID) ) then
Nenue@28 261 return OBJECTIVE_TRACKER_UPDATE_TASK_ADDED, questID
Nenue@28 262 else
Nenue@28 263 if ( AUTO_QUEST_WATCH == "1" and GetNumQuestWatches() < MAX_WATCHABLE_QUESTS ) then
Nenue@28 264 AddQuestWatch(questLogIndex);
Nenue@28 265 SetSuperTrackedQuestID(questID);
Nenue@28 266 end
Nenue@28 267 return OBJECTIVE_TRACKER_UPDATE_MODULE_QUEST
Nenue@28 268 end
Nenue@28 269 end
Nenue@28 270
Nenue@28 271 Event.QUEST_WATCH_LIST_CHANGED = function(questID, added)
Nenue@28 272 if ( added ) then
Nenue@28 273 if ( not IsQuestTask(questID) ) then
Nenue@28 274 return OBJECTIVE_TRACKER_UPDATE_QUEST_ADDED, questID, added
Nenue@28 275 end
Nenue@28 276 else
Nenue@28 277 return OBJECTIVE_TRACKER_UPDATE_QUEST, questID, added
Nenue@28 278 end
Nenue@28 279 end
Nenue@28 280
Nenue@28 281 Event.QUEST_POI_UPDATE = function()
Nenue@28 282 QuestPOIUpdateIcons();
Nenue@28 283 if ( GetCVar("trackQuestSorting") == "proximity" ) then
Nenue@28 284 SortQuestWatches();
Nenue@28 285 end
Nenue@28 286 return OBJECTIVE_TRACKER_UPDATE_ALL
Nenue@28 287 end
Nenue@28 288 Event.SUPER_TRACKED_QUEST_CHANGED = function()
Nenue@28 289 return OBJECTIVE_TRACKER_UPDATE_QUEST
Nenue@28 290 end
Nenue@28 291 Event.ZONE_CHANGED = function()
Nenue@28 292
Nenue@28 293 local inMicroDungeon = IsPlayerInMicroDungeon();
Nenue@28 294 if ( inMicroDungeon ~= T.inMicroDungeon ) then
Nenue@28 295 if ( not WorldMapFrame:IsShown() and GetCVarBool("questPOI") ) then
Nenue@28 296 SetMapToCurrentZone(); -- update the zone to get the right POI numbers for the tracker
Nenue@28 297 end
Nenue@28 298 --SortQuestWatches();
Nenue@28 299 T.inMicroDungeon = inMicroDungeon;
Nenue@28 300 end
Nenue@28 301 end
Nenue@28 302 Event.QUEST_AUTOCOMPLETE = function(questId)
Nenue@28 303 AddAutoQuestPopUp(questId, "COMPLETE");
Nenue@28 304 return OBJECTIVE_TRACKER_UPDATE_MODULE_QUEST + OBJECTIVE_TRACKER_UPDATE_MODULE_AUTO_QUEST_POPUP
Nenue@28 305 end
Nenue@28 306 Event.SCENARIO_CRITERIA_UPDATE = function()
Nenue@28 307 return OBJECTIVE_TRACKER_UPDATE_SCENARIO
Nenue@28 308 end
Nenue@28 309 Event.SCENARIO_UPDATE = function(newStage)
Nenue@28 310 if ( newStage ) then
Nenue@28 311 return OBJECTIVE_TRACKER_UPDATE_SCENARIO_NEW_STAGE
Nenue@28 312 else
Nenue@28 313 return OBJECTIVE_TRACKER_UPDATE_SCENARIO
Nenue@28 314 end
Nenue@28 315 end
Nenue@28 316 Event.TRACKED_ACHIEVEMENT_UPDATE = function()
Nenue@28 317 return OBJECTIVE_TRACKER_UPDATE_ACHIEVEMENT
Nenue@28 318 end
Nenue@28 319 Event.TRACKED_ACHIEVEMENT_LIST_CHANGED = function(achievementID, added)
Nenue@28 320 if ( added ) then
Nenue@28 321 return OBJECTIVE_TRACKER_UPDATE_ACHIEVEMENT_ADDED, achievementID
Nenue@28 322 else
Nenue@28 323 return OBJECTIVE_TRACKER_UPDATE_ACHIEVEMENT
Nenue@28 324 end
Nenue@28 325 end
Nenue@28 326 Event.ZONE_CHANGED_NEW_AREA = function ()
Nenue@28 327 if ( not WorldMapFrame:IsShown() and GetCVarBool("questPOI") ) then
Nenue@28 328 SetMapToCurrentZone(); -- update the zone to get the right POI numbers for the tracker
Nenue@28 329 end
Nenue@28 330 SortQuestWatches();
Nenue@28 331 T.currentZoneArea = GetCurrentMapAreaID()
Nenue@28 332 print('Updating zone ID to', T.currentZoneArea, '=', GetZoneText(), GetMinimapZoneText())
Nenue@28 333
Nenue@28 334
Nenue@28 335 return OBJECTIVE_TRACKER_UPDATE_TASK_ADDED
Nenue@28 336 end
Nenue@28 337
Nenue@28 338
Nenue@28 339 Event.PLAYER_MONEY = function()
Nenue@28 340 if T.watchMoneyReasons > 0 then
Nenue@28 341 return T.watchMoneyReasons
Nenue@28 342 end
Nenue@28 343 end
Nenue@28 344 Event.CRITERIA_COMPLETE = function()
Nenue@28 345 return OBJECTIVE_TRACKER_UPDATE_MODULE_BONUS_OBJECTIVE
Nenue@28 346 end
Nenue@28 347 Event.QUEST_TURN_IN = function(questID, xp, money)
Nenue@28 348 if ( IsQuestTask(questID) ) then
Nenue@28 349 T.Bonus:OnTurnIn(questID, xp, money)
Nenue@28 350 print('updating bonus modules (code', OBJECTIVE_TRACKER_UPDATE_MODULE_BONUS_OBJECTIVE, ',', questID, xp, money)
Nenue@28 351 return OBJECTIVE_TRACKER_UPDATE_MODULE_BONUS_OBJECTIVE, questID, xp, money
Nenue@28 352 else
Nenue@28 353 return OBJECTIVE_TRACKER_UPDATE_MODULE_QUEST, questID, xp, money
Nenue@28 354 end
Nenue@28 355 end
Nenue@28 356 T.Event = Event
Nenue@28 357
Nenue@28 358 --- Done once per ui load
Nenue@28 359 local BlizzHooks = {
Nenue@28 360 ['AddQuestWatch'] = 'AddQuestWatch',
Nenue@28 361 ['RemoveQuestWatch'] = 'RemoveQuestWatch',
Nenue@28 362 ['AbandonQuest'] = 'AbandonQuest',
Nenue@28 363 ['AcknowledgeAutoAcceptQuest'] = 'AcknowledgeAutoAcceptQuest',
Nenue@28 364 ['AddAutoQuestPopUp'] = 'AddAutoQuestPopUp',
Nenue@28 365 ['RemoveAutoQuestPopUp'] = 'RemoveAutoQuestPopUp',
Nenue@28 366 ['AddTrackedAchievement'] = 'AddTrackedAchievement',
Nenue@28 367 ['RemoveTrackedAchievement'] = 'RemoveTrackedAchievement',
Nenue@28 368 ['SetSuperTrackedQuestID'] = 'SetSuperTrackedQuestID'
Nenue@28 369 }
Nenue@28 370 local VeneerData
Nenue@28 371
Nenue@28 372 T.SetWatchMoney = function(watchMoney, reason)
Nenue@28 373 if watchMoney then
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 else
Nenue@28 378 if band(T.watchMoneyReasons, reason) > 0 then
Nenue@28 379 T.watchMoneyReasons = T.watchMoneyReasons - reason;
Nenue@28 380 end
Nenue@28 381 end
Nenue@28 382 end
Nenue@28 383 T.animateReasons = 0
Nenue@28 384 T.SetAnimate = function(reason)
Nenue@28 385 print('comparing', T.animateReasons, reason)
Nenue@28 386 if animate then
Nenue@28 387 if band(T.animateReasons, reason) == 0 then
Nenue@28 388 T.animateReasons = T.animateReasons + reason
Nenue@28 389 end
Nenue@28 390 else
Nenue@28 391 if band(T.animateReasons, reason) > 0 then
Nenue@28 392 T.animateReasons = T.animateReasons - reason
Nenue@28 393 end
Nenue@28 394 end
Nenue@28 395 end
Nenue@28 396
Nenue@28 397 local Play = function(file) if Devian and Devian.InWorkspace() then PlaySoundFile(file) end end
Nenue@28 398
Nenue@28 399 function T:OnEvent (event, ...)
Nenue@28 400 local isHandled
Nenue@28 401 print('OnEvent(|cFF00FF00'.. event ..'|r):', ...)
Nenue@28 402 local reason, arg1, arg2, arg3
Nenue@28 403 if Event[event] then
Nenue@28 404 if type(Event[event]) == 'function' then
Nenue@28 405 Play([[Interface\Addons\SharedMedia_MyMedia\sound\Info.ogg]])
Nenue@28 406 reason, arg1, arg2, arg3 = Event[event](...)
Nenue@28 407 elseif type(Event[event]) == 'table' then
Nenue@28 408 Play([[Interface\Addons\SharedMedia_MyMedia\sound\Link.ogg]])
Nenue@28 409 for i, action in ipairs(Event[event]) do
Nenue@28 410 if type(action) == 'function' then
Nenue@28 411 reason, arg1, arg2, arg3 = action(event, ...)
Nenue@28 412 else
Nenue@28 413 reason = action
Nenue@28 414 end
Nenue@28 415
Nenue@28 416 if reason then
Nenue@28 417 T:Update(reason, arg1, arg2, arg3)
Nenue@28 418 end
Nenue@28 419 end
Nenue@28 420 else
Nenue@28 421 Play([[Interface\Addons\SharedMedia_MyMedia\sound\Heart.ogg]])
Nenue@28 422 reason = Event[event]
Nenue@28 423 end
Nenue@28 424 else
Nenue@28 425 Play([[Interface\Addons\SharedMedia_MyMedia\sound\Quack.ogg]])
Nenue@28 426 end
Nenue@28 427 if reason then
Nenue@28 428 T:Update(reason, arg1, arg2, arg3)
Nenue@28 429 else
Nenue@28 430 print('no reason value returned')
Nenue@28 431 Play([[Interface\Addons\SharedMedia_MyMedia\sound\Quack.ogg]])
Nenue@28 432 end
Nenue@28 433
Nenue@28 434 end
Nenue@28 435
Nenue@28 436
Nenue@28 437 function T:OnInitialize()
Nenue@28 438 local c = T.Conf.Wrapper
Nenue@28 439 VeneerData = _G.VeneerData
Nenue@28 440 VeneerData.CallLog = VeneerData.CallLog or {}
Nenue@28 441 if not T.isHooked then
Nenue@28 442 T.isHooked = true
Nenue@28 443 for blizzFunc, veneerFunc in pairs(BlizzHooks) do
Nenue@28 444 if T[veneerFunc] then
Nenue@28 445 hooksecurefunc(blizzFunc, T[veneerFunc])
Nenue@28 446 else
Nenue@28 447 hooksecurefunc(blizzFunc, function(...)
Nenue@28 448 print('|cFFFF0088securehook('..tostring(blizzFunc)..')|r args:', ...)
Nenue@28 449 tinsert(VeneerData.CallLog, {blizzFunc, ...})
Nenue@28 450 end)
Nenue@28 451 end
Nenue@28 452 end
Nenue@28 453 end
Nenue@28 454
Nenue@28 455 T.Conf.TasksLog = T.Conf.TasksLog or {}
Nenue@28 456
Nenue@28 457 ObjectiveTrackerFrame:UnregisterAllEvents()
Nenue@28 458 ObjectiveTrackerFrame:Hide()
Nenue@28 459
Nenue@28 460
Nenue@28 461 for id, name in ipairs(T.orderedNames) do
Nenue@28 462 if not T.orderedHandlers[id] then
Nenue@28 463 Handler_Initialize(T.DefaultHandler, name, id)
Nenue@28 464 end
Nenue@28 465 end
Nenue@28 466 self:SetSize(c.Width, 40)
Nenue@28 467 T.InitializeWidgets()
Nenue@28 468 end
Nenue@28 469
Nenue@28 470 --- Done any time the the minimize button is toggled up
Nenue@28 471 function T:OnEnable()
Nenue@28 472
Nenue@28 473 print(B.Conf.VeneerObjectiveWrapper.enabled)
Nenue@28 474 if not B.Conf.VeneerObjectiveWrapper.enabled then
Nenue@28 475 return
Nenue@28 476 end
Nenue@28 477
Nenue@28 478 for event, action in pairs(Event) do
Nenue@28 479 print('|cFFFF0088listen to', event, 'for action|r', tostring(action))
Nenue@28 480 Wrapper:RegisterEvent(event)
Nenue@28 481 end
Nenue@28 482
Nenue@28 483 local c = T.Conf.Wrapper
Nenue@28 484
Nenue@28 485 Scroller:SetScrollChild(Scroll)
Nenue@28 486 Scroller:SetWidth(c.Width)
Nenue@28 487 Scroll:SetWidth(c.Width)
Nenue@28 488 Scroll:ClearAllPoints()
Nenue@28 489 Scroll:SetPoint('TOP', Scroller, 'TOP')
Nenue@28 490 self:SetScript('OnEvent', T.OnEvent)
Nenue@28 491
Nenue@28 492 Scroller:Show()
Nenue@28 493
Nenue@28 494 local from, target, to, x, y = Wrapper:GetPoint(1)
Nenue@28 495 print(from, target:GetName(), to, x,y)
Nenue@28 496
Nenue@28 497 T:Update()
Nenue@28 498
Nenue@28 499 -- run once to prime the data structure
Nenue@28 500 T.UpdateActionButtons()
Nenue@28 501 end
Nenue@28 502
Nenue@28 503 function T:OnDisable()
Nenue@28 504 self:UnregisterAllEvents()
Nenue@28 505 Scroller:Hide()
Nenue@28 506 end
Nenue@28 507