annotate QuestPOI.lua @ 63:8e130c92698f

- Added methods for obtaining pin data, and registering callbacks on data updates.
author Nick@Zahhak
date Tue, 21 Mar 2017 16:36:12 -0400
parents abcdef801db5
children 876c3f0bfd0e
rev   line source
Nenue@7 1 -- WorldPlan
Nenue@7 2 -- QuestPOI.lua
Nenue@7 3 -- Created: 10/1/2016 7:21 PM
Nenue@7 4 -- %file-revision%
Nenue@7 5 --
Nenue@40 6 local _, db = ...
Nenue@29 7
Nenue@29 8 local TQ_GetQuestInfoByQuestID = C_TaskQuest.GetQuestInfoByQuestID -- Return the name of a quest with a given ID
Nenue@7 9 local TQ_GetQuestLocation = C_TaskQuest.GetQuestLocation
Nenue@7 10 local TQ_GetQuestTimeLeftMinutes = C_TaskQuest.GetQuestTimeLeftMinutes
Nenue@9 11 local TQ_IsActive = C_TaskQuest.IsActive
Nenue@29 12 local TQ_RequestPreloadRewardData = C_TaskQuest.RequestPreloadRewardData
Nenue@7 13 local QuestPOIGetIconInfo, WorldMapPOIFrame = QuestPOIGetIconInfo, WorldMapPOIFrame
Nenue@33 14 local WorldMap_DoesWorldQuestInfoPassFilters = WorldMap_DoesWorldQuestInfoPassFilters
Nenue@33 15 local QuestMapFrame_IsQuestWorldQuest = QuestMapFrame_IsQuestWorldQuest
Nenue@40 16 local GetAchievementNumCriteria, GetAchievementCriteriaInfo, GetAchievementInfo = GetAchievementNumCriteria, GetAchievementCriteriaInfo, GetAchievementInfo
Nenue@40 17 local pairs, ipairs, tinsert, unpack, select = pairs, ipairs, tinsert, unpack, select
Nenue@40 18 local floor, mod, tostring, tonumber, GetSuperTrackedQuestID = floor, mod, tostring, tonumber, GetSuperTrackedQuestID
Nenue@33 19 local GameTooltip = GameTooltip
Nenue@33 20 local GetItemIcon = GetItemIcon
Nenue@7 21
Nenue@33 22 local print = DEVIAN_WORKSPACE and function(...) _G.print('POI', ...) end or function() end
Nenue@7 23 local qprint = DEVIAN_WORKSPACE and function(...) _G.print('POI', ...) end or function() end
Nenue@33 24 local wprint = DEVIAN_WORKSPACE and function(...) _G.print('WP', ...) end or function() end
Nenue@30 25 local wqprint = DEVIAN_WORKSPACE and function(...) _G.print('WorldQuests', ...) end or function() end
Nenue@7 26 local iprint = DEVIAN_WORKSPACE and function(...) _G.print('ItemScan', ...) end or function() end
Nenue@40 27 local rprint = DEVIAN_WORKSPACE and function(...) _G.print('WQRefresh', ...) end or function() end
Nenue@49 28 local dprint = DEVIAN_WORKSPACE and function(...) _G.print('WQData', ...) end or function() end
Nenue@7 29 local QuestPOI = WorldPlanPOIMixin
Nenue@7 30
Nenue@56 31 local pinBaseIndex = 1300
Nenue@56 32 local overlayBaseIndex = 1350
Nenue@56 33 local previousHighlight
Nenue@40 34
Nenue@40 35 local PIN_REFRESH_DELAY = .5
Nenue@54 36 local PIN_REQUEST_DELAY = .1
Nenue@9 37 local ICON_UNKNOWN = "Interface\\ICONS\\inv_misc_questionmark"
Nenue@9 38 local ICON_MONEY = "Interface\\Buttons\\UI-GroupLoot-Coin-Up"
Nenue@9 39
Nenue@40 40 local WORLD_QUEST_BORDER = "Interface\\UNITPOWERBARALT\\Generic1Target_Circular_Frame"
Nenue@47 41 local PENDING_BORDER = "Interface\\BUTTONS\\YELLOWORANGE64"
Nenue@40 42 local PENDING_ICON = "Interface\\BUTTONS\\YELLOWORANGE64"
Nenue@9 43
Nenue@29 44 local REWARD_CASH = WORLD_QUEST_REWARD_TYPE_FLAG_GOLD
Nenue@29 45 local REWARD_ARTIFACT_POWER = WORLD_QUEST_REWARD_TYPE_FLAG_ARTIFACT_POWER
Nenue@29 46 local REWARD_GEAR = WORLD_QUEST_REWARD_TYPE_FLAG_EQUIPMENT
Nenue@29 47 local REWARD_CURRENCY = WORLD_QUEST_REWARD_TYPE_FLAG_ORDER_RESOURCES
Nenue@29 48 local REWARD_REAGENT = WORLD_QUEST_REWARD_TYPE_FLAG_MATERIALS
Nenue@29 49
Nenue@29 50 local LE_QUEST_TAG_TYPE_PVP = LE_QUEST_TAG_TYPE_PVP
Nenue@29 51 local LE_QUEST_TAG_TYPE_PET_BATTLE = LE_QUEST_TAG_TYPE_PET_BATTLE
Nenue@29 52 local LE_QUEST_TAG_TYPE_DUNGEON = LE_QUEST_TAG_TYPE_DUNGEON
Nenue@29 53 local LE_QUEST_TAG_TYPE_PROFESSION = LE_QUEST_TAG_TYPE_PROFESSION
Nenue@29 54 local LE_QUEST_TAG_TYPE_NORMAL = LE_QUEST_TAG_TYPE_NORMAL
Nenue@29 55
Nenue@29 56 local LE_QUEST_TAG_TYPE_PVP = LE_QUEST_TAG_TYPE_PVP
Nenue@29 57 local LE_QUEST_TAG_TYPE_PET_BATTLE = LE_QUEST_TAG_TYPE_PET_BATTLE
Nenue@29 58 local LE_QUEST_TAG_TYPE_DUNGEON = LE_QUEST_TAG_TYPE_DUNGEON
Nenue@29 59 local LE_QUEST_TAG_TYPE_PROFESSION = LE_QUEST_TAG_TYPE_PROFESSION
Nenue@29 60 local LE_QUEST_TAG_TYPE_NORMAL = LE_QUEST_TAG_TYPE_NORMAL
Nenue@29 61
Nenue@40 62 local STYLE_TYPE_PENDING = 768
Nenue@40 63
Nenue@31 64
Nenue@29 65 -- Pin color/display variables
Nenue@40 66 db.TooltipExtras = db.TooltipExtras or {} -- idiot-proofing
Nenue@49 67 db.PinAlpha = 1
Nenue@29 68
Nenue@33 69 local familiars = {
Nenue@40 70 [42159] = 'Nightwatcher Merayl',
Nenue@40 71 [40277] = 'Tiffany Nelson',
Nenue@40 72 [40298] = 'Sir Galveston',
Nenue@40 73 [40282] = 'Grixis Tinypop',
Nenue@40 74 [40278] = 'Robert Craig',
Nenue@40 75 [48195] = 'Aulier',
Nenue@40 76 [41990] = 'Varenne',
Nenue@40 77 [41860] = 'Xorvasc',
Nenue@40 78 [40299] = 'Bodhi Sunwayver',
Nenue@40 79 [42442] = 'Amalia',
Nenue@40 80 [40280] = 'Bredda Tenderhide',
Nenue@40 81 [41687] = 'Odrogg',
Nenue@40 82 [41944] = 'Trapper Jarrun',
Nenue@40 83 [40337] = 'Master Tamer Flummox',
Nenue@40 84 [40279] = 'Durian Strongfruit'
Nenue@40 85 }
Nenue@40 86 local falcosaurs = {
Nenue@40 87 [44895] = {44881, 'Sharptalon Hatchling', 115786},
Nenue@40 88 [44894] = {44882, 'Bloodgazer Hatchling', 115787},
Nenue@40 89 [44893] = {44880, 'Direbeak Hatchling', 115785},
Nenue@40 90 [44892] = {44879, 'Snowfeather Hatchling', 115784},
Nenue@33 91 }
Nenue@33 92 local familiars_id = 9696
Nenue@40 93 for questID, name in pairs(familiars) do
Nenue@40 94 db.TooltipExtras[questID] = {{
Nenue@40 95 achievementID = familiars_id,
Nenue@40 96 name = name
Nenue@40 97 }}
Nenue@40 98 end
Nenue@40 99 for questID, info in pairs(falcosaurs) do
Nenue@40 100 local trackingQuestID, petName, petID = unpack(info)
Nenue@33 101
Nenue@40 102 db.TooltipExtras[questID] = {{
Nenue@40 103 questID = trackingQuestID,
Nenue@40 104 pet = petName,
Nenue@40 105 petID = petID
Nenue@40 106 }}
Nenue@9 107 end
Nenue@7 108
Nenue@40 109 local GetAchievementTooltipExtras = function(info)
Nenue@29 110
Nenue@40 111 local hasInfo
Nenue@40 112 local achievementID = info.achievementID
Nenue@40 113 local _, name, _, completed, _, _, _, _, _, icon = GetAchievementInfo(achievementID)
Nenue@40 114 if not completed then
Nenue@40 115
Nenue@40 116 local numItems = GetAchievementNumCriteria(achievementID)
Nenue@40 117 local numNeeded = 0
Nenue@40 118 local tooltipLines = {}
Nenue@40 119 for i =1, numItems do
Nenue@40 120 local criteriaName, criteriaType, completed, _, _, _, _, subAchievementID = GetAchievementCriteriaInfo(achievementID, i)
Nenue@49 121 --print(GetAchievementCriteriaInfo(achievementID, i))
Nenue@40 122
Nenue@40 123 if not completed then
Nenue@49 124 --print('::', criteriaName, completed, subAchievementID)
Nenue@40 125 if criteriaType == 8 then
Nenue@40 126 local _, _, _, completed, _, _, _, _, _, subIcon = GetAchievementInfo(subAchievementID)
Nenue@49 127 --print(' -', criteriaName, completed, subIcon)
Nenue@40 128 if not completed then
Nenue@40 129 local numCompleted = 0
Nenue@40 130 local numSubItems = GetAchievementNumCriteria(subAchievementID)
Nenue@40 131 local subCriteriaLine
Nenue@40 132 for j = 1, numSubItems do
Nenue@40 133 local subName, _, completed = GetAchievementCriteriaInfo(subAchievementID, j)
Nenue@40 134
Nenue@49 135 --print(' -',subName, completed)
Nenue@40 136 if completed then
Nenue@40 137 numCompleted = numCompleted + 1
Nenue@40 138 else
Nenue@40 139 numNeeded = numNeeded + 1
Nenue@40 140 if subName:match(info.name) then
Nenue@40 141 hasInfo = true
Nenue@40 142 subCriteriaLine = ' |T'..subIcon..':16:16|t ' .. criteriaName
Nenue@40 143 end
Nenue@40 144 end
Nenue@40 145
Nenue@40 146 end
Nenue@40 147 if subCriteriaLine then
Nenue@40 148 tinsert(tooltipLines, subCriteriaLine .. ' ('..numCompleted..'/'..numSubItems..')')
Nenue@40 149 end
Nenue@40 150 end
Nenue@40 151 elseif criteriaName:match(info.name) and (not completed) then
Nenue@40 152 numNeeded = numNeeded + 1
Nenue@40 153 tinsert(tooltipLines, criteriaName)
Nenue@40 154 end
Nenue@40 155 end
Nenue@40 156 end
Nenue@49 157 if hasInfo then
Nenue@49 158 WorldMapTooltip:AddLine(" ")
Nenue@49 159 WorldMapTooltip:AddLine("Achievements:")
Nenue@49 160 WorldMapTooltip:AddLine(' |T'..icon..':20:20|t '..name)
Nenue@40 161 for i, line in ipairs(tooltipLines) do
Nenue@40 162 WorldMapTooltip:AddLine(line)
Nenue@40 163 end
Nenue@40 164 end
Nenue@40 165 end
Nenue@40 166 return hasInfo
Nenue@40 167 end
Nenue@40 168
Nenue@40 169 local GetQuestTooltipExtras = function(info)
Nenue@40 170 local questID = info.questID
Nenue@40 171 local hasInfo
Nenue@40 172
Nenue@40 173 if info.pet then
Nenue@40 174 local index, guid = C_PetJournal.FindPetIDByName(info.pet)
Nenue@40 175 if not index then
Nenue@40 176 hasInfo = true
Nenue@40 177 WorldMapTooltip:AddLine('Pets:')
Nenue@40 178 WorldMapTooltip:AddLine(' - ' .. info.petName)
Nenue@40 179
Nenue@40 180 if not IsQuestFlaggedCompleted(questID) then
Nenue@40 181 WorldMapTooltip:AddLine(' Required Quest Flags', 1, 1, 0)
Nenue@40 182 else
Nenue@40 183 WorldMapTooltip:AddLine(' Quest Flags Complete!', 0, 1, 0)
Nenue@40 184 end
Nenue@40 185
Nenue@40 186 end
Nenue@29 187 end
Nenue@29 188
Nenue@29 189 end
Nenue@29 190
Nenue@40 191 local GetFactionInfoByID, GetQuestObjectiveInfo = GetFactionInfoByID, GetQuestObjectiveInfo
Nenue@40 192
Nenue@40 193 function QuestPOI:OnEnter()
Nenue@57 194 if self.filtered and (self.questID ~= GetSuperTrackedQuestID()) then
Nenue@49 195 return
Nenue@7 196 end
Nenue@57 197 WorldMap_HijackTooltip(self.owningFrame);
Nenue@56 198 self:SetFrameLevel(pinBaseIndex+100)
Nenue@56 199 self.Overlay:SetFrameLevel(pinBaseIndex+101)
Nenue@56 200
Nenue@56 201 if previousHighlight then
Nenue@56 202 previousHighlight:SetFrameLevel(pinBaseIndex+previousHighlight:GetID())
Nenue@56 203 previousHighlight.Overlay:SetFrameLevel(overlayBaseIndex+previousHighlight:GetID())
Nenue@56 204 end
Nenue@56 205
Nenue@56 206 previousHighlight = self
Nenue@56 207
Nenue@56 208
Nenue@40 209 WorldMapTooltip:SetOwner(self, "ANCHOR_RIGHT");
Nenue@49 210 --print('doing tooltip stuff')
Nenue@40 211
Nenue@40 212 -- Can't add stuff after, so most of the blizzard tooltip hook is simply copied over
Nenue@40 213 local questID = self.questID
Nenue@40 214 local color = WORLD_QUEST_QUALITY_COLORS[self.rarity] or NORMAL_FONT_COLOR;
Nenue@40 215
Nenue@40 216
Nenue@40 217 WorldMapTooltip:SetText(self.title, color.r, color.g, color.b);
Nenue@40 218 QuestUtils_AddQuestTypeToTooltip(WorldMapTooltip, questID, NORMAL_FONT_COLOR);
Nenue@40 219
Nenue@40 220 if ( self.factionID ) then
Nenue@40 221 local factionName = GetFactionInfoByID(self.factionID);
Nenue@40 222 if ( factionName ) then
Nenue@40 223 if (self.capped) then
Nenue@40 224 WorldMapTooltip:AddLine(factionName, GRAY_FONT_COLOR:GetRGB());
Nenue@40 225 else
Nenue@40 226 WorldMapTooltip:AddLine(factionName);
Nenue@40 227 end
Nenue@40 228 end
Nenue@40 229 end
Nenue@40 230
Nenue@40 231 if self.worldQuest then
Nenue@40 232 WorldMap_AddQuestTimeToTooltip(questID);
Nenue@40 233 end
Nenue@40 234
Nenue@40 235
Nenue@40 236 for objectiveIndex = 1, self.numObjectives do
Nenue@40 237 local objectiveText, objectiveType, finished = GetQuestObjectiveInfo(questID, objectiveIndex, false);
Nenue@40 238 if ( objectiveText and #objectiveText > 0 ) then
Nenue@40 239 local color = finished and GRAY_FONT_COLOR or HIGHLIGHT_FONT_COLOR;
Nenue@40 240 WorldMapTooltip:AddLine(QUEST_DASH .. objectiveText, color.r, color.g, color.b, true);
Nenue@40 241 end
Nenue@40 242 end
Nenue@40 243
Nenue@40 244 local percent = C_TaskQuest.GetQuestProgressBarInfo(self.questID);
Nenue@40 245 if ( percent ) then
Nenue@40 246 GameTooltip_InsertFrame(WorldMapTooltip, WorldMapTaskTooltipStatusBar);
Nenue@40 247 WorldMapTaskTooltipStatusBar.Bar:SetValue(percent);
Nenue@40 248 WorldMapTaskTooltipStatusBar.Bar.Label:SetFormattedText(PERCENTAGE_STRING, percent);
Nenue@40 249 end
Nenue@40 250
Nenue@40 251 if db.TooltipExtras[self.questID] then
Nenue@40 252 for index, info in pairs(db.TooltipExtras[questID]) do
Nenue@40 253 if info.achievementID then
Nenue@40 254 GetAchievementTooltipExtras(info)
Nenue@40 255 end
Nenue@40 256 if info.questID then
Nenue@40 257 GetQuestTooltipExtras(info)
Nenue@40 258 end
Nenue@40 259 end
Nenue@40 260 end
Nenue@40 261 WorldMap_AddQuestRewardsToTooltip(questID)
Nenue@40 262
Nenue@40 263 WorldMapTooltip:Show()
Nenue@40 264 --WorldMapTooltip.recalculatePadding = true;
Nenue@40 265 --print(WorldMapTooltip:GetParent())
Nenue@40 266 --print(WorldMapTooltip:IsVisible())
Nenue@7 267 end
Nenue@40 268 function QuestPOI:OnLeave()
Nenue@57 269 if self.filtered and (self.questID ~= GetSuperTrackedQuestID()) then
Nenue@57 270 return
Nenue@57 271 end
Nenue@35 272 WorldMap_RestoreTooltip()
Nenue@40 273 WorldMapTooltip:Hide();
Nenue@7 274 end
Nenue@7 275
Nenue@40 276 -- attempt to pull pin data
Nenue@40 277 local GetQuestTagInfo, GetProfessionInfo = GetQuestTagInfo, GetProfessionInfo
Nenue@40 278 function QuestPOI:GetData ()
Nenue@49 279 dprint('|cFF00FF88'..self:GetID()..':GetData()|r')
Nenue@40 280 local questID = self.questID
Nenue@40 281 if not questID then
Nenue@49 282 dprint('|cFFFF4400bad pin|r', self:GetName())
Nenue@40 283 return nil
Nenue@29 284 end
Nenue@29 285
Nenue@40 286 local questTitle, factionID, capped = TQ_GetQuestInfoByQuestID(questID)
Nenue@40 287 -- if the title is nil, then wait and try later
Nenue@40 288 if not questTitle then
Nenue@54 289 if not self.isPending then
Nenue@54 290 C_TaskQuest.RequestPreloadRewardData(questID)
Nenue@54 291 self.isPending = true
Nenue@54 292 end
Nenue@49 293 dprint('|cFFBB8844isPending=true|r|cFF00FFFF', self.questId)
Nenue@40 294 else
Nenue@40 295 self.title, self.factionID, self.capped = questTitle, factionID, capped
Nenue@49 296 dprint('|cFFBB8844 data|r|cFF00FFFF', (self.isPending and '|cFFFF4400delayed|r' or '|cFF00FF00success|r'), self.title, '|r', self.factionID)
Nenue@49 297 if self.dataLoaded then
Nenue@49 298 dprint(' |cFFFF4400overwriting data|r')
Nenue@49 299 end
Nenue@49 300
Nenue@40 301 -- set tag details
Nenue@40 302 local worldQuestType
Nenue@40 303 self.tagID, self.tagName, worldQuestType, self.rarity, self.isElite, self.tradeskillLineIndex = GetQuestTagInfo(questID);
Nenue@40 304 local tagAtlas
Nenue@40 305 if worldQuestType == LE_QUEST_TAG_TYPE_PET_BATTLE then
Nenue@40 306 tagAtlas = "worldquest-icon-petbattle"
Nenue@40 307 elseif worldQuestType == LE_QUEST_TAG_TYPE_PVP then
Nenue@40 308 tagAtlas = "worldquest-icon-pvp-ffa"
Nenue@40 309 elseif worldQuestType == LE_QUEST_TAG_TYPE_PROFESSION then
Nenue@40 310 self.isKnownProfession = nil
Nenue@40 311 local id = self.tradeskillLineIndex and select(7, GetProfessionInfo(self.tradeskillLineIndex))
Nenue@40 312 if id then
Nenue@40 313 self.isKnownProfession = true
Nenue@40 314 qprint('profession' , self.title, id)
Nenue@40 315 tagAtlas = WORLD_QUEST_ICONS_BY_PROFESSION[id]
Nenue@40 316 end
Nenue@40 317 elseif worldQuestType == LE_QUEST_TAG_TYPE_DUNGEON then
Nenue@40 318 tagAtlas = "worldquest-icon-dungeon"
Nenue@40 319 end
Nenue@40 320 self.worldQuestType = worldQuestType
Nenue@40 321 self.tagAtlas = tagAtlas
Nenue@29 322
Nenue@40 323 self:SetRewardInfo()
Nenue@40 324
Nenue@40 325 -- force throttle on success
Nenue@40 326 --qprint(' |cFF00FFFF'..questID..'|r hasUpdate:', hasUpdate, 'isPending:', isPending, 'isShown', self:IsShown())
Nenue@40 327 --qprint(' ', 'rewardType:', self.rewardType, 'tag:', self.tagID)
Nenue@40 328 qprint(' ', tostring(self.title), " |T"..tostring(self.itemTexture)..":12:12|t", tostring(self.itemName))
Nenue@40 329
Nenue@40 330 if self.itemTexture and self.itemName and self.title then
Nenue@49 331 self.dataLoaded = true
Nenue@40 332 self.isPending = nil
Nenue@40 333 self.throttle = 1
Nenue@40 334 self.updateRate = PIN_REFRESH_DELAY
Nenue@48 335 self.isStale = true
Nenue@40 336 end
Nenue@40 337 end
Nenue@40 338
Nenue@40 339 self.isCriteria = WorldMapFrame.UIElementsFrame.BountyBoard:IsWorldQuestCriteriaForSelectedBounty(questID)
Nenue@40 340
Nenue@40 341 return self.isStale, self.isPending
Nenue@40 342 end
Nenue@40 343
Nenue@40 344 local GetNumQuestLogRewards, GetNumQuestLogRewardCurrencies, HaveQuestData = GetNumQuestLogRewards, GetNumQuestLogRewardCurrencies, HaveQuestData
Nenue@40 345 local GetQuestLogRewardMoney, GetQuestLogRewardCurrencyInfo, GetMoneyString = GetQuestLogRewardMoney, GetQuestLogRewardCurrencyInfo, GetMoneyString
Nenue@40 346 function QuestPOI:SetRewardInfo()
Nenue@40 347 local questID = self.questID
Nenue@29 348 if not HaveQuestData(questID) then
Nenue@40 349 self.isPending = true
Nenue@29 350 else
Nenue@29 351
Nenue@40 352 local rewardIcon, rewardName, rewardCount, rewardStyle, rewardType, itemID, quantity, quality
Nenue@29 353 -- set reward category
Nenue@29 354 local numRewards = GetNumQuestLogRewards(questID)
Nenue@29 355 local numCurrency = GetNumQuestLogRewardCurrencies(questID)
Nenue@29 356 local money = GetQuestLogRewardMoney(questID)
Nenue@29 357 if numRewards >= 1 then
Nenue@40 358 rewardType, rewardIcon, rewardCount, rewardName, itemID, quality = WorldPlanQuests:GetRewardHeader(questID)
Nenue@29 359 elseif numCurrency >= 1 then
Nenue@29 360 rewardName, rewardIcon, rewardCount = GetQuestLogRewardCurrencyInfo(1, questID)
Nenue@29 361 rewardType = REWARD_CURRENCY
Nenue@29 362 elseif money >= 1 then
Nenue@29 363 rewardIcon = ICON_MONEY
Nenue@29 364 rewardName = GetMoneyString(money)
Nenue@29 365 rewardType = REWARD_CASH
Nenue@29 366 end
Nenue@29 367
Nenue@49 368 qprint(' '..self.questID..':|cFFFFFF00SetRewardInfo():', numRewards, rewardType)
Nenue@40 369 self.itemNumber = tonumber(rewardCount or self.itemNumber)
Nenue@49 370 self.rewardType = rewardType
Nenue@31 371 self.quality = quality
Nenue@29 372
Nenue@40 373 self.itemTexture = rewardIcon or self.itemTexture
Nenue@40 374 self.itemName = rewardName or self.itemName
Nenue@29 375
Nenue@29 376 -- flag unresolved info
Nenue@29 377 if not (rewardIcon and rewardName) then
Nenue@40 378 self.isPending = true
Nenue@48 379 self.isStale = nil
Nenue@29 380 --WorldPlan:print('|cFFFFFF00'..tostring(self.title)..'|r waiting on texture info')
Nenue@29 381 else
Nenue@40 382 if (rewardIcon and rewardName) and self.isPending then
Nenue@29 383 --WorldPlan:print('|cFF00FF00'..tostring(self.title)..'|r has info', rewardIcon, rewardName)
Nenue@40 384 self.isStale = true
Nenue@29 385 end
Nenue@40 386 self.isPending = nil
Nenue@29 387 end
Nenue@29 388
Nenue@40 389 end
Nenue@7 390 end
Nenue@7 391
Nenue@34 392 -- run from OnShow if .isNew is set
Nenue@34 393
Nenue@49 394 function QuestPOI:StartFade()
Nenue@34 395 if not self.isAnimating then
Nenue@35 396 --qprint('|cFFFFFF00'.. self.title .. ' added to quest log.')
Nenue@35 397 self:SetAlpha(0)
Nenue@49 398 self.FadeIn.FadeIn:SetToAlpha(db.PinAlpha)
Nenue@49 399 self.PendingFade.FadeIn:SetToAlpha(db.PinAlpha)
Nenue@49 400 self.PendingFade.FadeOut:SetFromAlpha(db.PinAlpha)
Nenue@49 401
Nenue@34 402 self.isAnimating = true
Nenue@35 403 self.isNew = nil
Nenue@40 404 self.isStale = true
Nenue@35 405 self.FadeIn:Play()
Nenue@34 406 end
Nenue@7 407 end
Nenue@7 408
Nenue@49 409 function QuestPOI:EndFade()
Nenue@49 410 self.isAnimating = nil
Nenue@49 411 self:SetAlpha(db.PinAlpha)
Nenue@49 412 end
Nenue@49 413
Nenue@40 414 function QuestPOI:OnShow ()
Nenue@27 415
Nenue@49 416 if self.isStale then
Nenue@49 417 qprint('|cFF0088FFflagged for refresh')
Nenue@48 418 self:Refresh()
Nenue@48 419 end
Nenue@34 420
Nenue@54 421 if self.isNew or (not self.Overlay:IsShown()) then
Nenue@54 422 --qprint('|cFFFFFF00popping new pin handler')
Nenue@49 423 self:StartFade()
Nenue@49 424 end
Nenue@49 425
Nenue@54 426 if not self.isAnimating then
Nenue@57 427 self:SetAlpha(db.PinAlpha) -- fix stuck alpha
Nenue@54 428 end
Nenue@59 429
Nick@62 430 self:ShowFrames()
Nenue@27 431 end
Nick@62 432
Nenue@40 433 function QuestPOI:OnHide()
Nick@60 434 --DEFAULT_CHAT_FRAME:AddMessage('|cFFFFFF00'..self:GetName()..'|r:OnHide()')
Nick@62 435 self:HideFrames()
Nenue@59 436 -- reset flags
Nenue@59 437 self:SetAlpha(db.PinAlpha)
Nenue@49 438 self.isAnimating = nil
Nenue@27 439 end
Nenue@27 440
Nenue@57 441 -- different from owningFrame
Nenue@52 442 function QuestPOI:SetAnchor(owner, dX, dY, mapWidth, mapHeight)
Nick@62 443 wqprint(self:GetName()..':SetAnchor()', owner, dX, dY, self.filtered, self.used)
Nick@62 444 if not self.used then
Nick@62 445 self:HideFrames()
Nick@62 446 return
Nick@62 447 end
Nick@62 448
Nick@62 449
Nenue@52 450 self:SetParent(owner)
Nenue@49 451 self:ClearAllPoints()
Nenue@56 452 self:SetFrameLevel(pinBaseIndex + self:GetID())
Nenue@53 453 self.Overlay:SetParent(owner)
Nenue@53 454 self.Overlay:SetFrameLevel(overlayBaseIndex + self:GetID())
Nenue@53 455 if (dX and dY) then
Nenue@53 456 if not (mapHeight and mapWidth) then
Nenue@53 457 mapWidth, mapHeight = owner:GetSize()
Nenue@53 458 end
Nenue@53 459 local pX = (dX * mapWidth)
Nenue@53 460 local pY = (-dY * mapHeight)
Nenue@53 461 self.x = dX
Nenue@53 462 self.y = dY
Nenue@53 463 self:SetPoint('CENTER', owner, 'TOPLEFT', pX, pY)
Nenue@53 464 else
Nenue@53 465 self:SetPoint('CENTER')
Nenue@53 466 end
Nick@62 467
Nick@62 468 self:ShowFrames()
Nick@62 469 end
Nick@62 470
Nick@62 471
Nick@62 472 function QuestPOI:ShowFrames()
Nick@62 473 if not self:IsShown() then
Nick@63 474 --self:SetShown(true)
Nick@62 475 print('|cFFFFFF00' ..self:GetName()..':ShowFrames()')
Nick@62 476 qprint('|cFFFFFF00'..tostring(self:GetName())..':OnShow()|r update:', self.isStale, 'new:', self.isNew, 'animation:', self.isAnimating)
Nick@62 477 else
Nick@62 478
Nick@62 479 --print(self:GetName()..':ShowFrames()')
Nick@62 480 end
Nick@62 481 self.count:SetShown(true)
Nick@62 482 self.Overlay:SetShown(true)
Nick@62 483 self.count:SetShown(true)
Nick@62 484 self.timeLabel:SetShown(true)
Nick@62 485 end
Nick@62 486
Nick@62 487 function QuestPOI:HideFrames()
Nick@62 488 if self:IsShown() then
Nick@62 489 print(self:GetName()..':HideFrames()')
Nick@62 490 self:SetShown(false)
Nick@62 491 end
Nick@62 492 self.count:SetShown(false)
Nick@62 493 self.Overlay:SetShown(false)
Nick@62 494 self.count:SetShown(false)
Nick@62 495 self.timeLabel:SetShown(false)
Nick@62 496 self.used = nil
Nenue@7 497 end
Nenue@7 498
Nenue@40 499 function QuestPOI:OnLoad()
Nenue@40 500 qprint('|cFF00FF88'..self:GetName()..':OnLoad()|r',db.Config)
Nenue@7 501 self:RegisterEvent('SUPER_TRACKED_QUEST_CHANGED')
Nenue@36 502
Nenue@40 503 self.title = '|cFF0088FF' .. RETRIEVING_DATA..'|r'
Nenue@40 504 self.isPending = true
Nenue@36 505 self.count = self.Overlay.count
Nick@62 506 self.timeLabel = self.Overlay.timeLabel
Nenue@54 507 self.Description = self.Overlay.Description
Nenue@40 508 self.updateRate = PIN_REQUEST_DELAY
Nenue@40 509 self.itemName = '|cFF0088FF' .. RETRIEVING_DATA..'|r'
Nenue@41 510
Nenue@53 511 self.Overlay:SetPoint('TOPLEFT', self, 'TOPLEFT', 0, 4)
Nenue@53 512 self.Overlay:SetPoint('BOTTOMRIGHT', self, 'BOTTOMRIGHT', 0, -4)
Nenue@7 513 end
Nenue@57 514 function QuestPOI:OnMouseDown(button)
Nenue@57 515 if button == 'RightButton' then
Nenue@57 516 SetSuperTrackedQuestID(nil)
Nenue@57 517 else
Nenue@57 518 TaskPOI_OnClick(self, button)
Nenue@57 519 end
Nenue@57 520 end
Nenue@57 521
Nenue@7 522
Nenue@40 523 function QuestPOI:OnEvent(event, ...)
Nenue@7 524 if event == 'SUPER_TRACKED_QUEST_CHANGED' then
Nenue@33 525 self.isStale = true
Nenue@7 526 end
Nenue@7 527 end
Nenue@7 528
Nenue@40 529 function QuestPOI:OnUpdate (sinceLast)
Nenue@40 530 -- control update check intervals
Nenue@40 531 self.throttle = (self.throttle or self.updateRate) + sinceLast
Nenue@40 532 if self.throttle >= self.updateRate then
Nenue@40 533 -- factor overtime into the throttle timer
Nenue@40 534 self.throttle = self.throttle - self.updateRate
Nenue@40 535 else
Nenue@40 536 return
Nenue@40 537 end
Nenue@35 538 if self.isNew then
Nenue@59 539 --print('|cFFFFFF00push new poi stuff')
Nenue@35 540 self:OnNew()
Nenue@40 541 elseif (self.isStale or (not self.title)) and not self.isAnimating then
Nenue@59 542 --wprint('|cFFFFFF00push poi update')
Nenue@35 543 self:Refresh()
Nenue@35 544 return
Nenue@35 545 end
Nenue@7 546
Nenue@7 547 -- query for reward data if it wasn't found in the original scan
Nenue@7 548 local questID = self.questID
Nenue@7 549 if self.isPending then
Nenue@59 550 --print('|cFFFF4400'..self:GetID()..':|r polling reward info')
Nenue@49 551 if not (self.isAnimating) then
Nenue@7 552 self.PendingFade:Play()
Nenue@7 553 end
Nenue@49 554 self:GetData()
Nenue@7 555 return
Nenue@7 556 else
Nenue@7 557 if self.PendingFade:IsPlaying() then
Nenue@7 558 self.PendingFade:Stop()
Nenue@7 559 end
Nenue@7 560 end
Nenue@7 561
Nenue@55 562 self:UpdateStatus()
Nenue@55 563 end
Nenue@7 564
Nenue@55 565 -- Called at static intervals and with Refresh
Nenue@55 566 function QuestPOI:UpdateStatus()
Nenue@7 567 -- update time elements
Nenue@40 568 if TQ_IsActive(self.questID) then
Nenue@40 569 local tl = self.alertLevel
Nenue@55 570 local timeLeft = TQ_GetQuestTimeLeftMinutes(self.questID)
Nenue@40 571 if timeLeft > 0 then
Nenue@40 572
Nenue@40 573 local text, timeState = WorldPlan:GetTimeInfo(timeLeft, self.maxAlertLevel)
Nenue@40 574 if tl ~= timeState then
Nenue@40 575 tl = timeState
Nenue@40 576 self.timeLabel:SetText(text)
Nenue@40 577 end
Nenue@40 578 else
Nenue@9 579 if self.worldQuestType ~= LE_QUEST_TAG_TYPE_PROFESSION then
Nick@62 580 self:HideFrames()
Nenue@9 581 end
Nenue@7 582 end
Nenue@55 583
Nenue@57 584 if tl and (timeLeft < 120) then
Nenue@55 585 self.HighlightBorder:SetVertexColor(1,0,0,0.7)
Nenue@55 586 elseif self.isBounty then
Nenue@55 587 self.HighlightBorder:SetVertexColor(.25,.5,1,1)
Nenue@55 588 else
Nenue@55 589 self.HighlightBorder:SetVertexColor(0,0,0,0.7)
Nenue@55 590 end
Nenue@40 591 self.alertLevel = tl
Nick@60 592 self.timeLabel:SetShown(self.worldQuest and (self.maxAlertLevel >= 1))
Nenue@59 593 else
Nick@60 594 if not self.completed then
Nick@60 595 self.completed = true
Nick@60 596 WorldPlan:print('|cFFFFFF00'..tostring(self.title).. '|r is no longer active.')
Nick@62 597 self:HideFrames()
Nick@60 598 end
Nenue@7 599 end
Nenue@8 600 end
Nenue@8 601
Nick@60 602 function QuestPOI:Refresh ()
Nenue@49 603
Nick@60 604 rprint('|cFF00FF88'..self:GetID()..'|r:Refresh() type =', self.rewardType, 'title =', self.title)
Nenue@49 605
Nenue@49 606
Nenue@9 607
Nenue@40 608 local styleType = (self.isPending and STYLE_TYPE_PENDING) or self.rewardType
Nenue@40 609 local style,subStyle = self:GetTypeInfo(self.rewardType)
Nenue@52 610 if (self.filtered or (not self.dataLoaded)) and (self.questID ~= GetSuperTrackedQuestID()) then
Nenue@40 611 subStyle = style.minimized
Nenue@40 612 end
Nenue@40 613 self.style = style
Nenue@40 614 self.subStyle = subStyle
Nenue@40 615 --print(style, subStyle)
Nenue@40 616 self.currentWidth = subStyle.iconWidth
Nenue@40 617 self.borderWidth = subStyle.borderWidth
Nenue@40 618 self.highlightWidth = subStyle.highlightWidth
Nenue@40 619 self.tagSize = subStyle.TagSize
Nenue@40 620 self.maxAlertLevel = subStyle.maxAlertLevel
Nenue@40 621 self.NoIcon = subStyle.NoIcon
Nenue@9 622
Nenue@57 623 local questID = self.questID
Nenue@36 624 local iconBorder = self.RewardBorder
Nenue@36 625 local trackingBorder = self.HighlightBorder
Nenue@9 626 local icon = self.icon
Nenue@9 627 local count = self.count
Nenue@55 628 self.isBounty = WorldMapFrame.UIElementsFrame.BountyBoard:IsWorldQuestCriteriaForSelectedBounty(self.questID)
Nenue@36 629
Nenue@9 630 if self.itemName then
Nenue@45 631
Nenue@54 632 if self.itemNumber then
Nenue@54 633 local numberString = self.itemNumber
Nenue@54 634 if self.itemNumber >= 1000 then
Nenue@54 635 local numeral = floor(self.itemNumber/1000)
Nenue@54 636 local decimal = mod(self.itemNumber, 1000)
Nenue@54 637 numberString = numeral
Nenue@54 638 if decimal > 100 then
Nenue@54 639 numberString = numberString .. '.' .. tostring(floor(decimal/100))
Nenue@54 640 end
Nenue@54 641 numberString = numberString .. 'k'
Nenue@40 642 end
Nenue@45 643 self.count:SetText(numberString)
Nenue@45 644 else
Nenue@54 645 self.count:SetText(nil)
Nenue@45 646 end
Nenue@54 647 end
Nenue@30 648
Nenue@55 649 if db.Config.ShowVerboseInfo then
Nenue@55 650 self.Description:SetText(self.title .. "\n" .. floor(self.x*100+.5) .. "," .. floor(self.y*100+.5))
Nenue@55 651 end
Nenue@55 652
Nenue@40 653
Nenue@40 654 icon:SetMask("Interface\\Minimap\\UI-Minimap-Background")
Nenue@36 655 if self.itemTexture then
Nenue@47 656 --iconBorder:SetTexture(WORLD_QUEST_BORDER)
Nenue@40 657
Nenue@40 658 if self.NoIcon then
Nenue@40 659 icon:SetTexture(PENDING_ICON)
Nenue@40 660 icon:SetDesaturated(true)
Nenue@47 661 icon:SetVertexColor(style.r, style.g, style.b)
Nenue@40 662 else
Nenue@40 663
Nenue@40 664 icon:SetTexture(self.itemTexture)
Nenue@40 665 icon:SetDesaturated(false)
Nenue@40 666 icon:SetVertexColor(1, 1, 1)
Nenue@40 667 end
Nenue@40 668 else
Nenue@47 669 --
Nenue@40 670 icon:SetTexture(PENDING_ICON)
Nenue@40 671 icon:SetDesaturated(true)
Nenue@47 672 icon:SetVertexColor(style.r, style.g, style.b)
Nenue@9 673 end
Nenue@9 674
Nenue@47 675 iconBorder:SetMask("Interface\\Minimap\\UI-Minimap-Background")
Nenue@47 676 iconBorder:SetTexture(PENDING_BORDER)
Nenue@54 677 iconBorder:SetVertexColor(style.r, style.g, style.b, 1)
Nenue@52 678
Nenue@9 679 iconBorder:SetDesaturated(true)
Nenue@40 680 iconBorder:SetAlpha(subStyle.alpha or 1)
Nenue@9 681
Nenue@47 682 trackingBorder:SetMask("Interface\\Minimap\\UI-Minimap-Background")
Nenue@47 683 trackingBorder:SetTexture(PENDING_BORDER)
Nenue@9 684
Nenue@49 685 self.tagIcon:SetShown((not self.filtered) and true or false)
Nenue@9 686 self.tagIcon:SetAtlas(self.tagAtlas)
Nenue@49 687
Nenue@47 688 self.EliteBorder:SetShown(self.isElite and not self.filtered)
Nenue@36 689
Nenue@9 690 self:UpdateSize()
Nenue@55 691 self:UpdateStatus()
Nenue@33 692 self.isStale = nil
Nenue@57 693
Nenue@57 694 -- signal filter info update
Nenue@57 695 WorldPlanSummary.isStale = true
Nenue@9 696 end
Nenue@9 697
Nenue@35 698 local cvar_check = {
Nenue@35 699 [REWARD_CASH] = 'worldQuestFilterGold',
Nenue@35 700 [REWARD_ARTIFACT_POWER] = 'worldQuestFilterArtifactPower',
Nenue@35 701 [REWARD_CURRENCY] = 'worldQuestFilterOrderResources',
Nenue@35 702 [REWARD_REAGENT]= 'worldQuestFilterProfessionMaterials',
Nenue@35 703 [REWARD_GEAR] = 'worldQuestFilterEquipment',
Nenue@35 704 }
Nenue@8 705
Nenue@57 706 function QuestPOI:CheckFilterRules ()
Nenue@36 707 local print = qprint
Nenue@33 708 local qType = self.worldQuestType
Nenue@57 709 local filtered
Nenue@57 710 local canShow = TQ_IsActive(self.questID)
Nenue@52 711 if SpellCanTargetQuest() then
Nenue@52 712 -- hiding so player can click a valid target
Nenue@52 713 self.used = nil
Nenue@52 714 elseif qType == LE_QUEST_TAG_TYPE_PROFESSION then
Nenue@57 715 if not(self.isKnownProfession or db.Config.ShowAllProfessionQuests) then
Nenue@57 716 canShow = nil
Nenue@36 717 end
Nenue@36 718 end
Nenue@57 719 if canShow then
Nenue@57 720 for filterKey, value in pairs(db.UsedFilters) do
Nenue@57 721 if self[filterKey] ~= value then
Nenue@57 722 if not self.filtered then
Nenue@57 723 print('|cFFFF4400filtering', filterKey, value, '~=', self[filterKey], self.title)
Nenue@57 724 end
Nenue@57 725
Nenue@57 726 filtered = true
Nenue@57 727 end
Nenue@57 728 end
Nenue@57 729 if self.rewardType and cvar_check[self.rewardType] then
Nenue@57 730 if not GetCVarBool(cvar_check[self.rewardType]) then
Nenue@57 731 filtered = true
Nenue@57 732 end
Nenue@57 733 end
Nenue@57 734 if canShow and self.filtered ~= filtered then
Nenue@57 735 self.isStale = true
Nenue@57 736 print(' '..self.questID..':|cFFFFFF00CheckFilterRules()|r ', canShow, filtered, self.title)
Nenue@57 737 end
Nenue@57 738
Nenue@57 739 self.filtered = filtered
Nenue@57 740 end
Nenue@57 741
Nenue@57 742 self.used = canShow
Nenue@57 743
Nenue@57 744
Nenue@33 745 end
Nenue@33 746
Nenue@33 747 --- Fixes icons upon size update
Nenue@36 748 function QuestPOI:UpdateSize ()
Nenue@33 749
Nenue@49 750 --qprint('|cFF00BB88'..self:GetID()..'|r:UpdateSize()', self.style, self.subStyle)
Nenue@33 751
Nenue@40 752 local style = self.style
Nenue@40 753 local subStyle = self.subStyle
Nenue@36 754 local icon = self.icon
Nenue@36 755 local iconBorder = self.RewardBorder
Nenue@36 756 local trackingBorder = self.HighlightBorder
Nenue@36 757 local tag = self.tagIcon
Nenue@33 758
Nenue@36 759 local iconWidth = subStyle.iconWidth
Nenue@36 760 local borderWidth = iconWidth + (subStyle.borderWidth * 2)
Nenue@36 761 local highlightWidth = borderWidth + (subStyle.highlightWidth * 2)
Nenue@36 762 local iconTexture = self.itemTexture
Nenue@33 763
Nenue@47 764
Nenue@56 765 self:SetSize(highlightWidth, highlightWidth)
Nenue@47 766 if self.questID == GetSuperTrackedQuestID() then
Nenue@47 767 highlightWidth = highlightWidth + 2
Nenue@57 768 if self.filtered then
Nenue@57 769 self:SetAlpha(db.PinAlpha * 0.5)
Nenue@57 770 else
Nenue@57 771 self:SetAlpha(db.PinAlpha)
Nenue@57 772 end
Nenue@57 773
Nenue@47 774 end
Nenue@47 775
Nenue@47 776 if self.rarity and WORLD_QUEST_QUALITY_COLORS[self.rarity] then
Nenue@47 777 highlightWidth = highlightWidth + self.rarity
Nenue@47 778 end
Nenue@40 779 self.tagIcon:SetSize(self.tagSize, self.tagSize)
Nenue@36 780 icon:SetSize(iconWidth, iconWidth)
Nenue@36 781 iconBorder:SetSize(borderWidth, borderWidth)
Nenue@36 782 trackingBorder:SetSize(highlightWidth, highlightWidth)
Nenue@33 783
Nenue@36 784
Nenue@36 785 iconBorder:SetPoint('CENTER', (style.x or 0), (style.y or 0))
Nenue@36 786 trackingBorder:SetPoint('CENTER', (style.x or 0), (style.y or 0))
Nenue@36 787
Nenue@36 788
Nick@62 789 if (subStyle.showNumber and self.itemNumber) and style.hasNumeric then
Nenue@36 790 self.count:SetTextColor(unpack(style.numberRGB))
Nenue@36 791 if subStyle.numberFontObject then
Nenue@36 792 --wqprint('change font', _G[subStyle.numberFontObject]:GetName())
Nenue@36 793 self.count:SetFontObject(_G[subStyle.numberFontObject])
Nenue@36 794 end
Nick@62 795 else
Nick@62 796 self.count:SetText(nil)
Nenue@33 797 end
Nenue@7 798 end