-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathHonorAssist.lua
229 lines (188 loc) · 7.82 KB
/
HonorAssist.lua
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
local addonName, addonTable = ...
HonorAssist = addonTable
local HonorAssistFrame = CreateFrame("Frame", "HonorAssist", UIParent)
HonorAssistDEBUG = false
HonorAssistFrame:RegisterEvent("PLAYER_ENTERING_WORLD")
HonorAssistFrame:RegisterEvent("CHAT_MSG_COMBAT_HONOR_GAIN")
HonorAssistFrame:SetScript("OnUpdate", function(self, timeSinceLastUpdate) HonorAssist:OnUpdateTimer(timeSinceLastUpdate); end);
HonorAssistFrame:SetScript("OnEvent", function(self, event, ...)
if event == "PLAYER_ENTERING_WORLD" then
HonorAssist:ProcessPlayerEnteringWorld()
HonorAssist:UpdateBattlegroundState()
end
if event == "CHAT_MSG_COMBAT_HONOR_GAIN" then
HonorAssist:ProcessChatMsgCombatHonorGain(...)
end
if event == "CHAT_MSG_BG_SYSTEM_ALLIANCE" then
HonorAssist:UpdateBgFrameHordeFlagCarrier(...)
end
if event == "CHAT_MSG_BG_SYSTEM_HORDE" then
HonorAssist:UpdateBgFrameAllianceFlagCarrier(...)
end
if event == "UPDATE_BATTLEFIELD_SCORE" then
HonorAssist:UpdateBattlefieldScore()
end
if event == "COMBAT_LOG_EVENT_UNFILTERED" then
HonorAssist:ProcessCombatLogEventUnfiltered(...)
end
if event == "UNIT_HEALTH_FREQUENT" then
local unit = ...
HonorAssist:UpdateBgFrameHealth(unit)
HonorAssist:UpdateBgFramePower(unit)
end
if event == "UNIT_POWER_FREQUENT" then
local unit = ...
HonorAssist:UpdateBgFrameHealth(unit)
HonorAssist:UpdateBgFramePower(unit)
end
if event == "PLAYER_TARGET_CHANGED" then
HonorAssist:ReportNewBgUnit("target")
end
if event == "UNIT_TARGET" then
local unit = ...
HonorAssist:ReportNewBgUnit(unit .. "target")
HonorAssist:UpdateBgFrameHealth(unit .. "target")
HonorAssist:UpdateBgFramePower(unit .. "target")
end
if event == "UPDATE_MOUSEOVER_UNIT" then
HonorAssist:ReportNewBgUnit("mouseover")
HonorAssist:UpdateBgFrameHealth("mouseover")
HonorAssist:UpdateBgFramePower("mouseover")
end
end)
function HonorAssist:ProcessPlayerEnteringWorld()
if HonorAssistLogging == nil then
HonorAssistLogging = false
end
HonorAssist:Initialize()
end
function HonorAssist:Initialize()
-- Initialize the values for all services first.
HonorAssist:LoadDatabaseSettings()
HonorAssist:LoadDailySettings()
HonorAssist:LoadHourlySettings()
HonorAssist:LoadTrackerUiSettings()
HonorAssist:LoadHistoryLoader()
HonorAssist:LoadNameplateSettings()
HonorAssist:LoadBGFrames()
HonorAssist:LoadBGFramesUi()
-- Push data into all of the services from the master database.
-- 'All' currently includes HonorAssistDailyCalculator and HonorAssistHourlyCalculator.
HonorAssist:LoadDataSinceDateTimeUtc(HonorAssist:GetDailyStartTimeEpoch(), HonorAssist:GetHourlyStartTimeEpoch())
-- Always load options UI last.
HonorAssist:LoadOptionsUi()
end
function HonorAssist:ProcessChatMsgCombatHonorGain(honorGainedSummary)
local eventTimeUtc = HonorAssist:GetCurrentTimeUtc()
local estimatedHonorGained = string.match(honorGainedSummary, "%d+")
local playerKilled = string.match(honorGainedSummary, "^([^%s]+)")
local hasParentheses = string.match(honorGainedSummary, "%(")
-- If there is no number then it is a dishonorable kill. Ignore.
if estimatedHonorGained == nil then
return
end
-- If there is estimatedHonorGained, playerKilled, and parentheses in the summary then a player was killed.
if estimatedHonorGained ~= nil and playerKilled ~= nil and hasParentheses ~= nill then
HonorAssist:ProcessPlayerKillMessage(eventTimeUtc, estimatedHonorGained, playerKilled)
end
-- If there is estimatedHonorGained and no parentheses in the summary then bonus honor was gained.
if estimatedHonorGained ~= nil and hasParentheses == nil then
HonorAssist:ProcessBonusHonorMessage(eventTimeUtc, estimatedHonorGained)
end
end
function HonorAssist:ProcessPlayerKillMessage(eventTimeUtc, estimatedHonorGained, playerKilled)
HonorAssist:AddKillToMasterDatabase(playerKilled, estimatedHonorGained, eventTimeUtc)
local honorGained = HonorAssist:AddKillToDailyDatabase(playerKilled, estimatedHonorGained, eventTimeUtc)
HonorAssist:AddToHourlyDatabase(honorGained, eventTimeUtc)
HonorAssist:AddKillToHistory(playerKilled, estimatedHonorGained, eventTimeUtc)
end
function HonorAssist:ProcessBonusHonorMessage(eventTimeUtc, estimatedHonorGained)
HonorAssist:AddBonusHonorToMasterDatabase(estimatedHonorGained, eventTimeUtc)
local honorGained = HonorAssist:AddBonusHonorToDailyDatabase(tonumber(estimatedHonorGained), eventTimeUtc)
HonorAssist:AddToHourlyDatabase(honorGained, eventTimeUtc)
HonorAssist:AddBonusHonorToHistory(honorGained, eventTimeUtc)
end
function HonorAssist:OnUpdateTimer(timeSinceLastUpdate)
local time = GetTime()
if (time == nil) then
return
end
self.timeSinceLastUpdate = (self.timeSinceLastUpdate or 0) + timeSinceLastUpdate;
-- Update hourly calculator every minute.
if (self.timeSinceLastUpdate < 60) then
return
end
self.timeSinceLastUpdate = 0
-- Check to see if daily data needs to be reset
if (HonorAssist:GetHonorDayStartTimeEpoch() ~= HonorAssist:GetDailyStartTimeEpoch()) then
HonorAssist:Initialize()
return
end
-- Recalculate hourly data
HonorAssist:RecalculateHourlyData()
end
function HonorAssist:UpdateBattlegroundState()
local inInstance, instanceType = IsInInstance()
local name, instanceTypeTwo, difficultyID, difficultyName, maxPlayers, dynamicDifficulty, isDynamic, instanceID, instanceGroupSize, LfgDungeonID = GetInstanceInfo()
if (inInstance and instanceType == "pvp" and instanceID == 489 and HonorAssistBattlegroundFramesToggle) then
RequestBattlefieldScoreData()
isInBattleground = true
HonorAssistFrame:RegisterEvent("UPDATE_BATTLEFIELD_SCORE")
HonorAssistFrame:RegisterEvent("COMBAT_LOG_EVENT_UNFILTERED")
HonorAssistFrame:RegisterEvent("UNIT_HEALTH_FREQUENT")
HonorAssistFrame:RegisterEvent("UNIT_TARGET")
HonorAssistFrame:RegisterEvent("UPDATE_MOUSEOVER_UNIT")
HonorAssistFrame:RegisterEvent("PLAYER_TARGET_CHANGED")
HonorAssistFrame:RegisterEvent("CHAT_MSG_BG_SYSTEM_ALLIANCE")
HonorAssistFrame:RegisterEvent("CHAT_MSG_BG_SYSTEM_HORDE")
HonorAssist:ShowBattlegroundFramesWindow()
else
isInBattleground = false
HonorAssistFrame:UnregisterEvent("UPDATE_BATTLEFIELD_SCORE")
HonorAssistFrame:UnregisterEvent("COMBAT_LOG_EVENT_UNFILTERED")
HonorAssistFrame:UnregisterEvent("UNIT_HEALTH_FREQUENT")
HonorAssistFrame:UnregisterEvent("UNIT_TARGET")
HonorAssistFrame:UnregisterEvent("UPDATE_MOUSEOVER_UNIT")
HonorAssistFrame:UnregisterEvent("PLAYER_TARGET_CHANGED")
HonorAssistFrame:UnregisterEvent("CHAT_MSG_BG_SYSTEM_ALLIANCE")
HonorAssistFrame:UnregisterEvent("CHAT_MSG_BG_SYSTEM_HORDE")
HonorAssist:ClearAllBgFrames()
HonorAssist:HideBattlegroundFramesWindow()
end
end
SLASH_HONORASSIST1 = "/honorassist"
SLASH_HONORASSIST2 = "/honorassist help"
SLASH_HONORASSIST3 = "/honorassist show"
SLASH_HONORASSIST2 = "/honorassist reset"
SLASH_HONORASSIST4 = "/honorassist hide"
SLASH_HONORASSIST5 = "/honorassist debug"
SlashCmdList["HONORASSIST"] = function(msg)
if HonorAssist:StringIsNullOrEmpty(msg) then
HonorAssist:PrintHelpInformation()
end
local slashCommandMsg = HonorAssist:SplitString(msg, " ")
local subCommand = slashCommandMsg[1]
if subCommand == "help" then
HonorAssist:PrintHelpInformation()
end
if subCommand == "debug" then
HonorAssistDEBUG = not HonorAssistDEBUG
print('HonorAssist DEBUG = ' .. '|cFF00FFFF' .. tostring(HonorAssistDEBUG))
end
if subCommand == "show" then
HonorAssist:ShowTrackerUi(true)
end
if subCommand == "hide" then
HonorAssist:ShowTrackerUi(false)
end
if subCommand == "reset" then
HonorAssist:ResetPosition()
end
end
function HonorAssist:PrintHelpInformation()
print("HonorAssist Help Information")
print("/honorassist, /honorassist help -- Displays help information for HonorAssist addon.")
print("/honorassist show -- Shows the Honor Assist (Daily) tracker.")
print("/honorassist hide -- Hides the Honor Assist (Daily) tracker.")
print("/honorassist reset -- Resets the position of the Honor Assist (Daily) tracker.")
end