43716fe - Fix rested xp errors, update rested bonus when resting
[wowui.git] / OmaUF / UnitFrames.lua
index 8a49add..815fa17 100644 (file)
@@ -10,6 +10,7 @@ local GameTooltip_SetDefaultAnchor = nil;
 
 local registerEvents = OmaUFEvents.RegisterEvents;
 local unitEvent = OmaUFEvents.UnitEvent;
+local createAuraFrame = OmaUFAuras.CreateAuraFrame;
 
 local Settings = OmaUFSettings;
 local indSize = Settings.IndSize;
@@ -20,8 +21,8 @@ local shieldColor = Settings.ShieldColor;
 local shieldhlColor = Settings.ShieldhlColor;
 local healpredColor = Settings.HealpredColor;
 local healabsorbColor = Settings.HealabsorbColor;
+local width, height = Settings.Width, Settings.Height;
 -- placeholders with visible values when error happens
-local width, height = 10, 10;
 local anchorX, anchorY = 10, 10;
 local attributes = {};
 
@@ -68,7 +69,7 @@ local function frameHide(frame)
 end
 
 local function showTooltip(frame)
-    GameTooltip_SetDefaultAnchor(GameTooltip, PlayerFrame);
+    GameTooltip_SetDefaultAnchor(GameTooltip, frame);
     GameTooltip:SetUnit(frame:GetAttribute("unit"));
 end
 
@@ -151,7 +152,7 @@ local function setupFrame(frame, secure, unit)
     frame.role = frame:CreateTexture(nil, "OVERLAY");
     frame.role:SetPoint("TOPLEFT", frame.healthback, "TOPRIGHT", -8, 8);
     frame.role:SetPoint("BOTTOMRIGHT", frame.healthback, "TOPRIGHT", 8, -8);
-    frame.role:SetTexture("Interface\\LFGFRAME\\UI-LFG-ICON-ROLES");
+    frame.role:SetTexture("Interface\\LFGFRAME\\UI-LFG-ICON-PORTRAITROLES");
     frame.role:Hide();
     frame.status = frame:CreateTexture(nil, "OVERLAY");
     frame.status:SetPoint("TOPLEFT", frame.manaback, "BOTTOMLEFT", -8, 8);
@@ -159,10 +160,14 @@ local function setupFrame(frame, secure, unit)
     frame.status:SetTexture("Interface\\CHARACTERFRAME\\UI-StateIcon");
     frame.status:Hide();
     frame.pvp = frame:CreateTexture(nil, "OVERLAY");
-    frame.pvp:SetPoint("TOPLEFT", frame.healthback, "TOPLEFT", -6, 6);
-    frame.pvp:SetPoint("BOTTOMRIGHT", frame.healthback, "TOPLEFT", 16, -16);
+    frame.pvp:SetPoint("TOPLEFT", frame.manaback, "BOTTOMLEFT", 8, 6);
+    frame.pvp:SetPoint("BOTTOMRIGHT", frame.manaback, "BOTTOMLEFT", 32, -18);
     frame.pvp:SetTexture("Interface\\TARGETINGFRAME\\UI-PVP-Horde");
     frame.pvp:Hide();
+    frame.leader = frame:CreateTexture(nil, "OVERLAY");
+    frame.leader:SetPoint("TOPLEFT", frame.healthback, "TOPLEFT", -6, 6);
+    frame.leader:SetPoint("BOTTOMRIGHT", frame.healthback, "TOPLEFT", 6, -6);
+    frame.leader:Hide();
     frame.name = frame:CreateFontString(nil, "OVERLAY", "GameFontHighlightLarge");
     frame.name:SetPoint("LEFT", frame.healthback, "LEFT", 2, 1);
     frame.level = frame:CreateFontString(nil, "OVERLAY", "GameFontHighlight");
@@ -171,9 +176,6 @@ local function setupFrame(frame, secure, unit)
     frame:SetScript("OnShow", frameShow);
     frame:SetScript("OnHide", frameHide);
     frame:SetScript("OnEvent", unitEvent);
-    -- let other addons hook these to anchor tooltip elsewhere
-    GameTooltip = _G["GameTooltip"];
-    GameTooltip_SetDefaultAnchor = _G["GameTooltip_SetDefaultAnchor"];
     secure:SetScript("OnEnter", showTooltip);
     secure:SetScript("OnLeave", hideTooltip);
     -- set attributes
@@ -200,10 +202,10 @@ local function initializePlayer(parent)
     local secure = CreateFrame("Button", "OmaPlayerSecure", parent, inheritedFrames);
     local frame = CreateFrame("Frame", "OmaPlayer", parent);
     local unit = "player";
-    secure:SetPoint("CENTER", parent, "CENTER", -320, -100);
+    secure:SetPoint("CENTER", parent, "CENTER", -300, -175);
     secure:SetWidth(width+2);
     secure:SetHeight(height+2);
-    frame:SetPoint("CENTER", parent, "CENTER", -320, -100);
+    frame:SetPoint("CENTER", parent, "CENTER", -300, -175);
     frame:SetWidth(width+2);
     frame:SetHeight(height+2);
     setupFrame(frame, secure, unit);
@@ -217,39 +219,73 @@ local function initializeTarget(parent)
     local secure = CreateFrame("Button", "OmaTargetSecure", parent, inheritedFrames);
     local frame = CreateFrame("Frame", "OmaTarget", parent);
     local unit = "target";
-    secure:SetPoint("CENTER", parent, "CENTER", 320, -100);
+    secure:SetPoint("CENTER", parent, "CENTER", 300, -175);
     secure:SetWidth(width+2);
     secure:SetHeight(height+2);
-    frame:SetPoint("CENTER", parent, "CENTER", 320, -100);
+    frame:SetPoint("CENTER", parent, "CENTER", 300, -175);
     frame:SetWidth(width+2);
     frame:SetHeight(height+2);
     setupFrame(frame, secure, unit);
-    -- TODO target frame buffs/debuffs
+    createAuraFrame(frame, unit);
     RegisterUnitWatch(frame);
     RegisterUnitWatch(secure);
     RegisterStateDriver(secure, "vehicleui", "[vehicleui] vehicle; no");
     secure:SetAttribute("_onstate-vehicleui", vehicletoggle);
 end
 
+local function loadCharSettings()
+    anchorX, anchorY = Settings.Character.AnchorX, Settings.Character.AnchorY;
+    attributes = Settings.Character.Clickheal;
+end
+
 local function initialize()
+    loadCharSettings();
+    -- let other addons hook these to anchor tooltip elsewhere
+    GameTooltip = _G["GameTooltip"];
+    GameTooltip_SetDefaultAnchor = _G["GameTooltip_SetDefaultAnchor"];
     initializePlayer(UIParent);
     initializeTarget(UIParent);
+    -- TODO boss frames, pet frame, (arena frames)
 end
 
-local function loadCharSettings()
-    width, height = Settings.Character.Width, Settings.Character.Height;
-    anchorX, anchorY = Settings.Character.AnchorX, Settings.Character.AnchorY;
-    attributes = Settings.Character.Clickheal;
+local hidden = false;
+local function hideBlizzardFrames()
+    if hidden then return end
+    hidden = true;
+
+    for _, frame in pairs({PlayerFrame, TargetFrame, TargetFrameToT}) do
+        frame:UnregisterAllEvents();
+        frame.healthbar:UnregisterAllEvents();
+        frame.manabar:UnregisterAllEvents();
+        if frame.spellbar then frame.spellbar:UnregisterAllEvents() end
+        if frame.powerBarAlt then frame.powerBarAlt:UnregisterAllEvents() end
+        frame:Hide();
+    end
+
+    -- TODO create frames for class powers, currently using Simple Holy Power
+    for _, frame in pairs({PlayerFrameAlternateManaBar, ComboFrame,
+            PriestBarFrame, RuneFrame, WarlockPowerFrame, MonkHarmonyBarFrame,
+            PaladinPowerBarFrame, MageArcaneChargesFrame}) do
+        frame:UnregisterAllEvents();
+        frame:Hide();
+    end
+
+    -- from ShadowedUF, re-register vehicle events for default auras
+    PlayerFrame:RegisterEvent("PLAYER_ENTERING_WORLD");
+    PlayerFrame:RegisterEvent("UNIT_ENTERING_VEHICLE");
+    PlayerFrame:RegisterEvent("UNIT_ENTERED_VEHICLE");
+    PlayerFrame:RegisterEvent("UNIT_EXITING_VEHICLE");
+    PlayerFrame:RegisterEvent("UNIT_EXITED_VEHICLE");
+    PlayerFrame:SetMovable(true);
+    PlayerFrame:SetUserPlaced(true);
+    PlayerFrame:SetDontSavePosition(true);
 end
 
-UnitFrames:RegisterEvent("ADDON_LOADED");
 UnitFrames:RegisterEvent("PLAYER_LOGIN");
 UnitFrames:SetScript("OnEvent", function(self, event)
     if event == "PLAYER_LOGIN" then
-        initialize();
-    elseif event == "ADDON_LOADED" then
         OmaUFLoadChar();
-        loadCharSettings();
-        OmaUFEvents.LoadChar();
+        hideBlizzardFrames();
+        initialize();
     end
 end);