Rework inviter config
This commit is contained in:
11
Heimdall.lua
11
Heimdall.lua
@@ -10,7 +10,6 @@ local addonname, shared = ...
|
|||||||
local function init()
|
local function init()
|
||||||
---@class Heimdall_Data
|
---@class Heimdall_Data
|
||||||
---@field config HeimdallConfig
|
---@field config HeimdallConfig
|
||||||
---@field whitelist table<string, string>
|
|
||||||
---@field stinkies table<string, boolean>
|
---@field stinkies table<string, boolean>
|
||||||
if not Heimdall_Data then Heimdall_Data = {} end
|
if not Heimdall_Data then Heimdall_Data = {} end
|
||||||
|
|
||||||
@@ -38,6 +37,7 @@ local function init()
|
|||||||
---@field inviter HeimdallInviterConfig
|
---@field inviter HeimdallInviterConfig
|
||||||
---@field whisperNotify table<string, string>
|
---@field whisperNotify table<string, string>
|
||||||
---@field stinkies table<string, boolean>
|
---@field stinkies table<string, boolean>
|
||||||
|
---@field agents table<string, string>
|
||||||
|
|
||||||
---@class HeimdallSpotterConfig
|
---@class HeimdallSpotterConfig
|
||||||
---@field enabled boolean
|
---@field enabled boolean
|
||||||
@@ -72,7 +72,8 @@ local function init()
|
|||||||
---@field enabled boolean
|
---@field enabled boolean
|
||||||
---@field listeningChannel string
|
---@field listeningChannel string
|
||||||
---@field keyword string
|
---@field keyword string
|
||||||
---@field whitelist table<string, string>
|
---@field allAssist boolean
|
||||||
|
---@field agentsAssist boolean
|
||||||
|
|
||||||
--- Data ---
|
--- Data ---
|
||||||
---@class HeimdallMessengerData
|
---@class HeimdallMessengerData
|
||||||
@@ -155,8 +156,10 @@ local function init()
|
|||||||
enabled = shared.GetOrDefault(Heimdall_Data, { "config", "inviter", "enabled" }, false),
|
enabled = shared.GetOrDefault(Heimdall_Data, { "config", "inviter", "enabled" }, false),
|
||||||
listeningChannel = shared.GetOrDefault(Heimdall_Data, { "config", "inviter", "listeningChannel" }, "Agent"),
|
listeningChannel = shared.GetOrDefault(Heimdall_Data, { "config", "inviter", "listeningChannel" }, "Agent"),
|
||||||
keyword = shared.GetOrDefault(Heimdall_Data, { "config", "inviter", "keyword" }, "+"),
|
keyword = shared.GetOrDefault(Heimdall_Data, { "config", "inviter", "keyword" }, "+"),
|
||||||
whitelist = shared.GetOrDefault(Heimdall_Data, { "config", "inviter", "whitelist" }, {}),
|
allAssist = shared.GetOrDefault(Heimdall_Data, { "config", "inviter", "allAssist" }, false),
|
||||||
}
|
agentsAssist = shared.GetOrDefault(Heimdall_Data, { "config", "inviter", "agentsAssist" }, false),
|
||||||
|
},
|
||||||
|
agents = shared.GetOrDefault(Heimdall_Data, { "config", "agents" }, {}),
|
||||||
}
|
}
|
||||||
|
|
||||||
shared.raceMap = {
|
shared.raceMap = {
|
||||||
|
|||||||
83
Inviter.lua
83
Inviter.lua
@@ -1,94 +1,53 @@
|
|||||||
local addonname, data = ...
|
local addonname, shared = ...
|
||||||
---@cast data HeimdallData
|
---@cast shared HeimdallShared
|
||||||
---@cast addonname string
|
---@cast addonname string
|
||||||
|
|
||||||
data.Inviter = {}
|
shared.Inviter = {}
|
||||||
function data.Inviter.Init()
|
function shared.Inviter.Init()
|
||||||
if not data.config.inviter.enabled then
|
-- if not Heimdall_Data.config.inviter.enabled then
|
||||||
print("Heimdall - Inviter disabled")
|
-- print("Heimdall - Inviter disabled")
|
||||||
return
|
-- return
|
||||||
end
|
-- end
|
||||||
|
|
||||||
---@type table<string, boolean>
|
---@type table<string, boolean>
|
||||||
local channelMembers = {}
|
|
||||||
local channelRosterFrame = CreateFrame("Frame")
|
local channelRosterFrame = CreateFrame("Frame")
|
||||||
channelRosterFrame:RegisterEvent("CHANNEL_ROSTER_UPDATE")
|
channelRosterFrame:RegisterEvent("CHANNEL_ROSTER_UPDATE")
|
||||||
channelRosterFrame:SetScript("OnEvent", function(self, event, index)
|
channelRosterFrame:SetScript("OnEvent", function(self, event, index)
|
||||||
|
if not Heimdall_Data.config.inviter.enabled then return end
|
||||||
local count = select(5, GetChannelDisplayInfo(index))
|
local count = select(5, GetChannelDisplayInfo(index))
|
||||||
channelMembers = {}
|
|
||||||
for i = 1, count do
|
for i = 1, count do
|
||||||
local name = GetChannelRosterInfo(index, i)
|
local name = GetChannelRosterInfo(index, i)
|
||||||
if name then
|
if name then
|
||||||
channelMembers[name] = true
|
Heimdall_Data.config.agents[name] = date("%Y-%m-%dT%H:%M:%S")
|
||||||
data.config.inviter.whitelist[name] = date("%Y-%m-%dT%H:%M:%S")
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
|
|
||||||
---@param channelName string
|
|
||||||
---@return table<string, boolean>
|
|
||||||
local function UpdateChannelMembers(channelName)
|
|
||||||
local friendsFrame = _G["FriendsFrame"]
|
|
||||||
local channelFrame = _G["ChannelFrame"]
|
|
||||||
OpenFriendsFrame()
|
|
||||||
_G["FriendsFrameTab3"]:Click()
|
|
||||||
_G["ChannelButton2"]:Click()
|
|
||||||
for i = 1, 40 do
|
|
||||||
local button = _G["ChannelButton" .. i]
|
|
||||||
if not button then break end
|
|
||||||
local text = button:GetText()
|
|
||||||
if string.find(text, channelName) then
|
|
||||||
button:Click()
|
|
||||||
break
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
channelFrame:Hide()
|
|
||||||
friendsFrame:Hide()
|
|
||||||
return channelMembers
|
|
||||||
end
|
|
||||||
|
|
||||||
C_Timer.NewTicker(30, function()
|
|
||||||
UpdateChannelMembers(data.config.inviter.listeningChannel)
|
|
||||||
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
|
||||||
inviterGroupFrame:RegisterEvent("GROUP_ROSTER_UPDATE")
|
inviterGroupFrame:RegisterEvent("GROUP_ROSTER_UPDATE")
|
||||||
inviterGroupFrame:SetScript("OnEvent", function(self, event, ...)
|
inviterGroupFrame:SetScript("OnEvent", function(self, event, ...)
|
||||||
|
if not Heimdall_Data.config.inviter.enabled then return end
|
||||||
if not UnitIsGroupLeader("player") then return end
|
if not UnitIsGroupLeader("player") then return end
|
||||||
|
|
||||||
if not IsInRaid() then
|
if not IsInRaid() then
|
||||||
ConvertToRaid()
|
ConvertToRaid()
|
||||||
end
|
end
|
||||||
|
|
||||||
if nextUpdate >= GetTime() then return end
|
if Heimdall_Data.config.inviter.allAssist then
|
||||||
nextUpdate = GetTime() + data.config.inviter.updateInterval
|
SetEveryoneIsAssistant()
|
||||||
for name, _ in pairs(channelMembers) do
|
|
||||||
PromoteToAssistant(name, true)
|
|
||||||
end
|
end
|
||||||
for name, _ in pairs(data.config.inviter.whitelist) do
|
if Heimdall_Data.config.inviter.agentsAssist then
|
||||||
PromoteToAssistant(name, true)
|
for name, _ in pairs(Heimdall_Data.config.agents) do
|
||||||
|
PromoteToAssistant(name, true)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
-- if not IsEveryoneAssistant() then
|
|
||||||
-- SetEveryoneIsAssistant(true)
|
|
||||||
-- end
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
local inviterChannelFrame = CreateFrame("Frame")
|
local inviterChannelFrame = CreateFrame("Frame")
|
||||||
inviterChannelFrame:RegisterEvent("CHAT_MSG_CHANNEL")
|
inviterChannelFrame:RegisterEvent("CHAT_MSG_CHANNEL")
|
||||||
inviterChannelFrame:SetScript("OnEvent", function(self, event, msg, sender, ...)
|
inviterChannelFrame:SetScript("OnEvent", function(self, event, msg, sender, ...)
|
||||||
|
if not Heimdall_Data.config.inviter.enabled then return end
|
||||||
local channelId = select(6, ...)
|
local channelId = select(6, ...)
|
||||||
local channelname = ""
|
local channelname = ""
|
||||||
---@type any[]
|
---@type any[]
|
||||||
@@ -103,11 +62,9 @@ function data.Inviter.Init()
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if channelname ~= data.config.inviter.listeningChannel then
|
if channelname ~= Heimdall_Data.config.inviter.listeningChannel then return end
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
if msg == data.config.inviter.keyword then
|
if msg == Heimdall_Data.config.inviter.keyword then
|
||||||
InviteUnit(sender)
|
InviteUnit(sender)
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
|
|||||||
Reference in New Issue
Block a user