Fix inviter channel scanning
It really was not so easy...
This commit is contained in:
@@ -128,6 +128,7 @@ local function init()
|
|||||||
--/run Heimdall_Data.config = {deathReporter={enabled=false},spotter={enabled=true,everyone=true}}
|
--/run Heimdall_Data.config = {deathReporter={enabled=false},spotter={enabled=true,everyone=true}}
|
||||||
--/run Heimdall_Data.config = {inviter={enabled=true},deathReporter={enabled=true},spotter={enabled=true,everyone=true}}
|
--/run Heimdall_Data.config = {inviter={enabled=true},deathReporter={enabled=true},spotter={enabled=true,everyone=true}}
|
||||||
--/run Heimdall_Data.config = {inviter={enabled=true,keyword="+++"},deathReporter={enabled=true},spotter={enabled=true,everyone=true}}
|
--/run Heimdall_Data.config = {inviter={enabled=true,keyword="+++"},deathReporter={enabled=true},spotter={enabled=true,everyone=true}}
|
||||||
|
--/run Heimdall_Data.config.inviter.enabled = true
|
||||||
data.config = {
|
data.config = {
|
||||||
spotter = {
|
spotter = {
|
||||||
enabled = data.GetOrDefault(Heimdall_Data, { "config", "spotter", "enabled" }, true),
|
enabled = data.GetOrDefault(Heimdall_Data, { "config", "spotter", "enabled" }, true),
|
||||||
|
|||||||
53
Inviter.lua
53
Inviter.lua
@@ -9,34 +9,57 @@ function data.Inviter.Init()
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
---@type table<string, boolean>
|
||||||
|
local channelMembers = {}
|
||||||
|
local channelRosterFrame = CreateFrame("Frame")
|
||||||
|
channelRosterFrame:RegisterEvent("CHANNEL_ROSTER_UPDATE")
|
||||||
|
channelRosterFrame:SetScript("OnEvent", function(self, event, index)
|
||||||
|
local count = select(5, GetChannelDisplayInfo(index))
|
||||||
|
channelMembers = {}
|
||||||
|
for i = 1, count do
|
||||||
|
local name = GetChannelRosterInfo(index, i)
|
||||||
|
if name then
|
||||||
|
channelMembers[name] = true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
|
||||||
---@param channelName string
|
---@param channelName string
|
||||||
---@return table<string, boolean>
|
---@return table<string, boolean>
|
||||||
local function GetChannelMembers(channelName)
|
local function UpdateChannelMembers(channelName)
|
||||||
|
local friendsFrame = _G["FriendsFrame"]
|
||||||
local channelFrame = _G["ChannelFrame"]
|
local channelFrame = _G["ChannelFrame"]
|
||||||
channelFrame:Show()
|
OpenFriendsFrame()
|
||||||
|
_G["FriendsFrameTab3"]:Click()
|
||||||
|
_G["ChannelButton2"]:Click()
|
||||||
for i = 1, 40 do
|
for i = 1, 40 do
|
||||||
local button = _G["ChannelButton" .. i]
|
local button = _G["ChannelButton" .. i]
|
||||||
if not button then break end
|
if not button then break end
|
||||||
local text = button:GetText()
|
local text = button:GetText()
|
||||||
if text == channelName then
|
if string.find(text, channelName) then
|
||||||
button:Click()
|
button:Click()
|
||||||
break
|
break
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local index = GetSelectedDisplayChannel()
|
channelFrame:Hide()
|
||||||
local count = select(5, GetChannelDisplayInfo(index))
|
friendsFrame:Hide()
|
||||||
local res = {}
|
return channelMembers
|
||||||
for i = 1, count do
|
|
||||||
local name = GetChannelRosterInfo(index, i)
|
|
||||||
if name then
|
|
||||||
res[name] = true
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
channelFrame:Hide()
|
C_Timer.NewTicker(30, function()
|
||||||
return res
|
UpdateChannelMembers(data.config.inviter.listeningChannel)
|
||||||
end
|
end)
|
||||||
|
|
||||||
|
-- print("pls joomp")
|
||||||
|
-- hooksecurefunc("JumpOrAscendStart", function()
|
||||||
|
-- print("JOOMP")
|
||||||
|
-- UpdateChannelMembers(data.config.inviter.listeningChannel)
|
||||||
|
-- local foo = channelMembers
|
||||||
|
-- for name, _ in pairs(foo) do
|
||||||
|
-- print(name)
|
||||||
|
-- end
|
||||||
|
-- end)
|
||||||
|
|
||||||
local inviterGroupFrame = CreateFrame("Frame")
|
local inviterGroupFrame = CreateFrame("Frame")
|
||||||
local nextUpdate = 0
|
local nextUpdate = 0
|
||||||
@@ -50,7 +73,7 @@ function data.Inviter.Init()
|
|||||||
|
|
||||||
if nextUpdate >= GetTime() then return end
|
if nextUpdate >= GetTime() then return end
|
||||||
nextUpdate = GetTime() + data.config.inviter.updateInterval
|
nextUpdate = GetTime() + data.config.inviter.updateInterval
|
||||||
for name, _ in pairs(GetChannelMembers(data.config.inviter.listeningChannel)) do
|
for name, _ in pairs(channelMembers) do
|
||||||
PromoteToAssistant(name, true)
|
PromoteToAssistant(name, true)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user