ChatSaver/ChatSaver.lua

102 lines
2.7 KiB
Lua
Raw Normal View History

ChatSaver = LibStub('AceAddon-3.0'):NewAddon('ChatSaver','AceConsole-3.0','AceHook-3.0','AceEvent-3.0');
2011-05-25 05:05:57 -04:00
local core = ChatSaver;
function core:OnInitialize()
self:RegisterChatCommand('cs','SlashCommand');
if(ChatSaverDB == nil) then
core.firstrun = true;
ChatSaverDB = {};
else
core.firstrun = false;
end
2011-05-25 05:05:57 -04:00
end
function core:OnEnable()
2011-05-29 06:36:07 -04:00
self:RawHook(SlashCmdList,'JOIN','JoinChannel',true);
self:RawHook(SlashCmdList,'LEAVE','LeaveChannel',true);
self:Hook('ToggleChatChannel','ToggleChatChannel',true);
self:RegisterEvent('CHANNEL_UI_UPDATE','RejoinChannels');
if(core.firstrun) then
self:RegisterEvent('CHAT_MSG_CHANNEL_NOTICE','SetupChatSaver');
end
end
function core:SlashCommand()
core:RejoinChannels();
end
function core:RejoinChannels(...)
local currentChannels = {};
2011-05-29 06:36:07 -04:00
for i = 1,select('#',GetChannelList()) do
currentChannels[select(i,GetChannelList())] = true
end
2011-05-25 05:36:29 -04:00
for channel,_ in pairs(ChatSaverDB) do
2011-05-27 15:08:27 -04:00
if(currentChannels[channel] == nil) then
2011-05-29 06:36:07 -04:00
JoinPermanentChannel(channel); -- does not place in chat frame properly
for index,_ in pairs(ChatSaverDB[channel].frames) do
ChatFrame_AddChannel(_G['ChatFrame'..index],channel);
end
2011-05-25 05:36:29 -04:00
end
end
self:UnregisterEvent('CHANNEL_UI_UPDATE');
end
2011-05-29 06:36:07 -04:00
function core:SetupChatSaver(...)
for frame = 1,NUM_CHAT_WINDOWS do
local chatWindowChannels = { GetChatWindowChannels(frame) };
2011-05-29 06:36:07 -04:00
for i = 1,#chatWindowChannels,2 do
local name,zone = chatWindowChannels[i], chatWindowChannels[i + 1];
if(zone == 0) then
if(ChatSaverDB[name] == nil) then
ChatSaverDB[name] = {};
ChatSaverDB[name]['frames'] = {};
ChatSaverDB[name]['index'] = GetChannelName(name);
end
ChatSaverDB[name]['frames'][frame] = true;
end
end
end
self:UnregisterEvent('CHAT_MSG_CHANNEL_NOTICE');
2011-05-25 05:05:57 -04:00
end
function core:JoinChannel(msg)
self.hooks[SlashCmdList].JOIN(msg);
local name = gsub(msg, "%s*([^%s]+).*", "%1");
2011-05-26 00:01:58 -04:00
if(strlen(name) > 0 and string.match(name,"%a+")) then
ChatSaverDB[name] = {};
ChatSaverDB[name]['frames'] = {};
ChatSaverDB[name]['index'] = GetChannelName(name);
ChatSaverDB[name]['frames'][DEFAULT_CHAT_FRAME:GetID()] = true;
end
end
function core:LeaveChannel(msg)
self.hooks[SlashCmdList].LEAVE(msg);
local number = gsub(msg, "%s*([^%s]+).*", "%1");
local _,name = GetChannelName(number);
ChatSaverDB[name] = nil;
end
function core:ToggleChatChannel(checked,channel)
2011-05-25 23:18:21 -04:00
if(ChatSaverDB[channel] == nil) then
return;
end
if(checked) then
ChatSaverDB[channel]['frames'][FCF_GetCurrentChatFrameID()] = true;
else
ChatSaverDB[channel]['frames'][FCF_GetCurrentChatFrameID()] = nil;
end
end