c6843f3 - Refactor updateIndicators to get auras when they're applied
[wowui.git] / OmaRF / Core.lua
index 74f5aed..d39b6e6 100644 (file)
@@ -1,17 +1,22 @@
-OmaRF = LibStub("AceAddon-3.0"):NewAddon("OmaRF");
+local unpack = unpack;
+local wipe = wipe;
+local next = next;
+local pairs = pairs;
+local ipairs = ipairs;
+
+OmaRF = CreateFrame("Frame");
 
 OmaRF.normalBarColor = CreateColor(0.3, 0.3, 0.3);
 OmaRF.dispelBarColor = CreateColor(1, 0.5, 0);
 OmaRF.normalBackColor = {0.7, 0.7, 0.7};
 OmaRF.dispelBackColor = {0.5, 0.2, 0};
-
 OmaRF.frames = {};
 OmaRF.majorFrames = {};
 OmaRF.positions = {
     "TOPLEFT", "TOPRIGHT", "CENTER", "BOTTOMLEFT", "BOTTOMRIGHT"
 };
-
 OmaRF.running = false;
+OmaRF.ooc_queue = {};
 
 local defaults = {
     profile = {
@@ -59,12 +64,27 @@ function OmaRF:OnDisable()
         end
         for _, ind in ipairs(self.majorFrames[name]) do
             ind.icon:Hide();
-            ind.expire:Hide();
-            ind.stack:Hide();
+            ind.expireText:Hide();
+            ind.stackText:Hide();
         end
     end
 end
 
+local function onEvent(self, event, ...)
+    if event == "PLAYER_REGEN_ENABLED" then
+        for _, t in pairs(self.ooc_queue) do
+            t.func(unpack(t.args));
+        end
+        if next(self.ooc_queue) ~= nil then
+            wipe(self.ooc_queue);
+        end
+    elseif event == "PLAYER_LOGIN" then
+        self:OnEnable();
+    elseif event == "ADDON_LOADED" then
+        self:OnInitialize();
+    end
+end
+
 SLASH_OMARF1 = "/omarf";
 function SlashCmdList.OMARF(msg, editBox)
     local loaded, finished = IsAddOnLoaded("OmaRFConfig");
@@ -92,3 +112,8 @@ function SlashCmdList.OMARF(msg, editBox)
     InterfaceOptionsFrame_OpenToCategory(OmaRF.optionsFrames.Profile);
     InterfaceOptionsFrame_OpenToCategory(OmaRF.optionsFrames.Indicators);
 end
+
+OmaRF:RegisterEvent("ADDON_LOADED");
+OmaRF:RegisterEvent("PLAYER_LOGIN");
+OmaRF:RegisterEvent("PLAYER_REGEN_ENABLED");
+OmaRF:SetScript("OnEvent", onEvent);