local _;
local CreateFrame = CreateFrame;
local UnitAura = UnitAura;
-local GameTooltip = nil;
+local GameTooltip = GameTooltip;
local auraFilters = {"HELPFUL", "HARMFUL"};
end
local function showTooltip(frame)
- -- tooltip handling from TargetFrame.xml
+ -- tooltip handling from FrameXML/TargetFrame.xml
GameTooltip:SetOwner(frame, "ANCHOR_BOTTOMRIGHT", 15, -25);
GameTooltip:SetUnitAura(frame.unit, frame.index, frame.filter);
frame:SetScript("OnUpdate", updateTooltip);
frame:SetScript("OnUpdate", nil);
end
+function M.UpdateAuraTooltips()
+ GameTooltip = _G["GameTooltip"];
+end
+
local function createAura(parent, prev, anchor, name, unit)
local aura = CreateFrame("Frame", name, parent);
aura:SetPoint("TOPLEFT", prev, anchor);
- aura:SetWidth(16);
- aura:SetHeight(16);
+ aura:SetWidth(20);
+ aura:SetHeight(20);
aura.icon = aura:CreateTexture(nil, "ARTWORK");
aura.icon:SetAllPoints();
+ aura.stack = aura:CreateFontString(nil, "OVERLAY", "NumberFontNormalSmall");
+ aura.stack:SetPoint("BOTTOMRIGHT");
aura.cd = CreateFrame("Cooldown", name.."CD", aura, "CooldownFrameTemplate");
aura.cd:SetReverse(true);
aura.cd:SetHideCountdownNumbers(true);
end
function M.CreateAuraFrame(parent, unit)
- GameTooltip = _G["GameTooltip"];
local name = parent:GetName().."Auras";
parent.auras = CreateFrame("Frame", name, parent);
parent.auras:SetPoint("TOPLEFT", parent, "BOTTOMLEFT", 0, -8);
i = i + 1;
end
-- max rows
- for y=0,1 do
+ for y=0,0 do
for x=1,10 do
local auraName = name..i;
parent.auras[i] = createAura(parent.auras, parent.auras[y*10+x], "BOTTOMLEFT", auraName, unit);
aura.icon:SetTexture(icon);
aura.index = i;
aura.filter = filter;
+ if count > 1 then
+ aura.stack:SetText(count);
+ aura.stack:Show();
+ else
+ aura.stack:Hide();
+ end
if expires > 0 then
aura.cd:SetCooldown(expires - duration, duration);
else