annotate SecureMenu.lua @ 124:f17fc88e971e

Remove trailing spaces
author contrebasse
date Sun, 11 Aug 2013 23:24:11 +0200
parents 5a3fb8fea026
children c6041a8cb7b8
rev   line source
contrebasse@0 1 local addonName, A = ...
contrebasse@0 2
contrebasse@111 3 -- Lua functions
contrebasse@111 4 local ipairs = ipairs
contrebasse@111 5 local type = type
contrebasse@111 6
contrebasse@111 7 -- Wow variables
contrebasse@111 8
contrebasse@0 9 -- Create the menu frame
contrebasse@34 10 local MenuFrame = CreateFrame("Frame","ReagentMaker_ExternalFrame",UIParent)
contrebasse@0 11 MenuFrame:Hide()
contrebasse@3 12 MenuFrame:SetSize(192,256)
contrebasse@110 13 --MenuFrame:SetFrameStrata("DIALOG")
contrebasse@3 14 MenuFrame:EnableMouse(true)
contrebasse@3 15 MenuFrame:SetPoint("CENTER")
contrebasse@110 16 MenuFrame:SetToplevel(true) -- raised if clicked
contrebasse@3 17 tinsert(UISpecialFrames,"ReagentMaker_ExternalFrame") -- make it closable with escape
contrebasse@2 18
contrebasse@115 19 -- Throttling is made in ReagentMaker.lua
contrebasse@115 20 MenuFrame:SetScript("OnEvent",function() MenuFrame:Hide() end)
contrebasse@115 21 MenuFrame:RegisterEvent("TRADE_SKILL_CLOSE")
contrebasse@115 22 MenuFrame:RegisterEvent("PLAYER_REGEN_DISABLED")
contrebasse@20 23
contrebasse@20 24 MenuFrame:SetScript("OnEnter",function(self)
contrebasse@20 25 if self.reagentLink then
contrebasse@20 26 GameTooltip:SetOwner(self)
contrebasse@20 27 GameTooltip:SetHyperlink(self.reagentLink)
contrebasse@20 28 GameTooltip:Show()
contrebasse@20 29 GameTooltip:ClearAllPoints()
contrebasse@20 30 GameTooltip:SetPoint("TOPRIGHT",self,"TOPLEFT",10,0)
contrebasse@32 31 if self.spellLink then
contrebasse@32 32 A.tooltipRecipe:SetOwner(GameTooltip)
contrebasse@32 33 A.tooltipRecipe:SetHyperlink(self.spellLink)
contrebasse@32 34 A.tooltipRecipe:Show()
contrebasse@32 35 A.tooltipRecipe:ClearAllPoints()
contrebasse@32 36 A.tooltipRecipe:SetPoint("TOPRIGHT",GameTooltip,"BOTTOMRIGHT")
contrebasse@32 37 end
contrebasse@20 38 end
contrebasse@20 39 end)
contrebasse@20 40 MenuFrame:SetScript("OnLeave",function()
contrebasse@20 41 GameTooltip:Hide()
contrebasse@32 42 A.tooltipRecipe:Hide()
contrebasse@20 43 end)
contrebasse@33 44
contrebasse@33 45 -- Hide frame when selecting a recipe which doesn't need this reagent
contrebasse@33 46 hooksecurefunc("SelectTradeSkill",function()
contrebasse@33 47 local selectedIndex = GetTradeSkillSelectionIndex()
contrebasse@111 48 for reagentIndexInRecipe = 1,GetTradeSkillNumReagents(selectedIndex) do
contrebasse@111 49 local reagentID = A.link2ID(GetTradeSkillReagentItemLink(selectedIndex, reagentIndexInRecipe))
contrebasse@33 50 if reagentID == MenuFrame.itemID or (MenuFrame.superItemID and reagentID == MenuFrame.superItemID) then
contrebasse@33 51 return
contrebasse@33 52 end
contrebasse@33 53 end
contrebasse@33 54 MenuFrame:Hide()
contrebasse@33 55 end)
contrebasse@3 56 A.MenuFrame = MenuFrame
contrebasse@3 57
contrebasse@3 58 -- Background adaptable vertically
contrebasse@3 59 local bg_top = MenuFrame:CreateTexture(nil,"BACKGROUND",nil,0)
contrebasse@3 60 bg_top:SetTexture("Interface\\LootFrame\\UI-LootPanel")
contrebasse@3 61 bg_top:SetSize(192,80)
contrebasse@3 62 bg_top:SetPoint("TOP")
contrebasse@3 63 bg_top:SetTexCoord(0,192/256,0,80/256)
contrebasse@3 64 local bg_bot = MenuFrame:CreateTexture(nil,"BACKGROUND",nil,0)
contrebasse@3 65 bg_bot:SetTexture("Interface\\LootFrame\\UI-LootPanel")
contrebasse@3 66 bg_bot:SetSize(192,16)
contrebasse@3 67 bg_bot:SetPoint("BOTTOM")
contrebasse@3 68 bg_bot:SetTexCoord(0,192/256,240/256,1)
contrebasse@3 69 local bg_mid = MenuFrame:CreateTexture(nil,"BACKGROUND",nil,0)
contrebasse@3 70 bg_mid:SetTexture("Interface\\LootFrame\\UI-LootPanel")
contrebasse@3 71 bg_mid:SetWidth(192)
contrebasse@3 72 bg_mid:SetPoint("TOP",bg_top,"BOTTOM")
contrebasse@3 73 bg_mid:SetPoint("BOTTOM",bg_bot,"TOP")
contrebasse@3 74 bg_mid:SetTexCoord(0,192/256,80/256,240/256)
contrebasse@3 75
contrebasse@3 76 -- Bouton de fermeture
contrebasse@3 77 local CloseButton = CreateFrame("Button",nil,MenuFrame,"UIPanelCloseButton");
contrebasse@3 78 CloseButton:SetPoint("TOPRIGHT",0,-10)
contrebasse@3 79
contrebasse@3 80 -- Main icon
contrebasse@3 81 local itemIcon = MenuFrame:CreateTexture(nil,"BACKGROUND",nil,-1)
contrebasse@3 82 itemIcon:SetSize(64,64)
contrebasse@3 83 itemIcon:SetPoint("TOPLEFT",8,-4)
contrebasse@3 84
contrebasse@3 85 -- Title
contrebasse@3 86 local TitleText = MenuFrame:CreateFontString(nil,"ARTWORK","GameFontHighlight")
contrebasse@45 87 --TitleText:SetSize(92,14)
contrebasse@45 88 TitleText:SetSize(92,36)
contrebasse@45 89 TitleText:SetPoint("TOPRIGHT",CloseButton,"TOPLEFT",4,-8)
contrebasse@45 90 TitleText:SetWordWrap(true)
contrebasse@45 91 TitleText:SetNonSpaceWrap(false)
contrebasse@45 92 TitleText:SetJustifyV("TOP")
contrebasse@45 93
contrebasse@3 94
contrebasse@3 95 local MENU_ENTRY_HEIGHT = 41
contrebasse@3 96 local MENU_ENTRY_WIDTH = 147
contrebasse@3 97 local MENU_ENTRY_ICON_RATIO = 40/48
contrebasse@2 98
contrebasse@0 99 local numActiveEntries = 0
contrebasse@0 100 local menuEntries = {}
contrebasse@0 101
contrebasse@3 102 -- Button hovering
contrebasse@5 103 local function btnEntered(btn)
contrebasse@20 104 if btn.numMakable and btn.numMakable>0 then
contrebasse@5 105 btn.textureHighlight:Show()
contrebasse@5 106 end
contrebasse@3 107
contrebasse@20 108 GameTooltip:SetOwner(btn,"ANCHOR_LEFT")
contrebasse@5 109 GameTooltip:SetHyperlink(btn.reagentLink)
contrebasse@5 110 GameTooltip:Show()
contrebasse@96 111 if btn.spellLink and btn.spellLink~=btn.reagentLink then
contrebasse@31 112 A.tooltipRecipe:SetOwner(GameTooltip)
contrebasse@31 113 A.tooltipRecipe:SetHyperlink(btn.spellLink)
contrebasse@31 114 A.tooltipRecipe:Show()
contrebasse@31 115 A.tooltipRecipe:ClearAllPoints()
contrebasse@31 116 A.tooltipRecipe:SetPoint("TOPRIGHT",GameTooltip,"BOTTOMRIGHT")
contrebasse@20 117 end
contrebasse@3 118 end
contrebasse@5 119 local function btnLeft(btn)
contrebasse@5 120 btn.textureHighlight:Hide()
contrebasse@5 121 GameTooltip:Hide()
contrebasse@5 122 A.tooltipRecipe:Hide()
contrebasse@3 123 end
contrebasse@3 124 local function createMenuEntry()
contrebasse@3 125 local btn = CreateFrame("Button", nil, MenuFrame, "SecureActionButtonTemplate")
contrebasse@3 126 table.insert(menuEntries,btn)
contrebasse@3 127
contrebasse@3 128 btn:Hide()
contrebasse@3 129 btn:SetSize(MENU_ENTRY_WIDTH,MENU_ENTRY_HEIGHT)
contrebasse@110 130 --btn:SetFrameStrata("DIALOG")
contrebasse@3 131
contrebasse@3 132 -- Set its position
contrebasse@3 133 if #menuEntries>1 then
contrebasse@3 134 btn:SetPoint("TOP",menuEntries[#menuEntries-1],"BOTTOM",0,-2)
contrebasse@2 135 else
contrebasse@3 136 btn:SetPoint("TOPLEFT",MenuFrame,"TOPLEFT",24,-79)
contrebasse@2 137 end
contrebasse@3 138
contrebasse@3 139 local icon = btn:CreateTexture(nil,"BACKGROUND")
contrebasse@3 140 icon:SetPoint("TOPLEFT")
contrebasse@3 141 icon:SetSize(39,39)
contrebasse@3 142 btn.icon = icon
contrebasse@3 143
contrebasse@3 144 local itemNameBG = btn:CreateTexture(nil,"BACKGROUND")
contrebasse@3 145 itemNameBG:SetTexture("Interface\\QuestFrame\\UI-QuestItemNameFrame")
contrebasse@3 146 itemNameBG:SetSize(128,64)
contrebasse@3 147 itemNameBG:SetPoint("LEFT",icon,"RIGHT",-10,0)
contrebasse@3 148
contrebasse@3 149 local itemName = btn:CreateFontString(nil,"BACKGROUND","GameFontHighlight")
contrebasse@3 150 itemName:SetSize(90,36)
contrebasse@3 151 itemName:SetPoint("LEFT",itemNameBG,"LEFT",15,0)
contrebasse@3 152 itemName:SetJustifyH("LEFT")
contrebasse@3 153 itemName:SetWordWrap(true)
contrebasse@3 154 itemName:SetNonSpaceWrap(false)
contrebasse@3 155 btn.itemName = itemName
contrebasse@3 156
contrebasse@3 157 local textureHighlight = btn:CreateTexture(nil,"BORDER")
contrebasse@3 158 textureHighlight:Hide()
contrebasse@3 159 textureHighlight:SetTexture("Interface\\BUTTONS\\CheckButtonHilight")
contrebasse@110 160 --textureHighlight:SetTexture("Interface\\BUTTONS\\ButtonHilight-Square")
contrebasse@3 161 textureHighlight:SetBlendMode("ADD")
contrebasse@3 162 textureHighlight:SetAllPoints(icon)
contrebasse@3 163 btn.textureHighlight = textureHighlight
contrebasse@5 164
contrebasse@5 165 local countDetail = btn:CreateFontString(nil,"ARTWORK","NumberFontNormal")
contrebasse@5 166 countDetail:SetPoint("BOTTOMRIGHT",icon,"BOTTOMRIGHT",-1,1)
contrebasse@5 167 countDetail:SetJustifyH("RIGHT")
contrebasse@5 168 countDetail:SetJustifyV("BOTTOM")
contrebasse@5 169 btn.countDetail = countDetail
contrebasse@5 170
contrebasse@10 171 local resultNumber = btn:CreateFontString(nil,"ARTWORK","NumberFontNormal")
contrebasse@11 172 resultNumber:SetPoint("TOPLEFT",icon,"TOPLEFT",1,-3)
contrebasse@10 173 resultNumber:SetJustifyH("LEFT")
contrebasse@10 174 resultNumber:SetJustifyV("TOP")
contrebasse@11 175 resultNumber:SetFont("Fonts\\ARIALN.TTF", 12, "OUTLINE")
contrebasse@10 176 btn.resultNumber = resultNumber
contrebasse@10 177
contrebasse@110 178 -- Used to choose the number of items to make
contrebasse@110 179 btn.SplitStack = A.SplitStack
contrebasse@110 180
contrebasse@20 181 btn:SetScript("OnEnter", btnEntered)
contrebasse@20 182 btn:SetScript("OnLeave", btnLeft)
contrebasse@3 183
contrebasse@3 184 return btn
contrebasse@2 185 end
contrebasse@1 186
contrebasse@40 187 local function WarnNotMakable(btn)
contrebasse@96 188 if not btn.reagentID then
contrebasse@96 189 A.Error(A.L["You do not have enough reagents to craft [%s]"]:format(TitleText:GetText()))
contrebasse@96 190 else
contrebasse@96 191 A.Error(A.L["You do not have enough [%s] to craft [%s]"]:format(btn.itemNameString,TitleText:GetText()))
contrebasse@96 192 end
contrebasse@40 193 end
contrebasse@40 194
contrebasse@110 195 local function CraftFromExternal(btn)
contrebasse@111 196 local chooseNumberToCraft = IsShiftKeyDown()
contrebasse@110 197
contrebasse@111 198 A.CraftItemWithRecipe( GetTradeSkillSelectionIndex(),
contrebasse@111 199 btn.itemID,
contrebasse@111 200 btn.reagent,
contrebasse@111 201 MenuFrame.reagentIndexInRecipe,
contrebasse@111 202 IsShiftKeyDown(),
contrebasse@111 203 btn)
contrebasse@110 204 end
contrebasse@110 205
contrebasse@40 206 -- Update counts and button actions
contrebasse@19 207 function MenuFrame.updateCounts()
contrebasse@3 208 local anyMakable
contrebasse@0 209 for i=1,numActiveEntries do
contrebasse@110 210 local btn = menuEntries[i]
contrebasse@3 211 local itemCount = GetItemCount(btn.reagentID)
contrebasse@3 212
contrebasse@110 213 local numMakable
contrebasse@110 214 if btn.reagentID then
contrebasse@110 215 numMakable = math.floor(itemCount/(btn.reagentsForOneRecipe or 1))
contrebasse@110 216 btn.countDetail:SetText(itemCount.."/"..(btn.reagentsForOneRecipe or 1))
contrebasse@110 217 else
contrebasse@110 218 for _,reagent in pairs(btn.reagentsForOneRecipe) do
contrebasse@110 219 itemCount = GetItemCount(reagent[1])
contrebasse@110 220 if not itemCount then
contrebasse@110 221 numMakable = 0
contrebasse@110 222 break
contrebasse@110 223 end
contrebasse@110 224 if not numMakable then
contrebasse@110 225 numMakable = math.floor(itemCount/reagent[2])
contrebasse@110 226 else
contrebasse@110 227 numMakable = math.min(numMakable,math.floor(itemCount/reagent[2]))
contrebasse@110 228 end
contrebasse@110 229 if numMakable==0 then break end
contrebasse@110 230 end
contrebasse@110 231 btn.countDetail:SetText(numMakable)
contrebasse@110 232 end
contrebasse@3 233
contrebasse@3 234 if numMakable>0 then
contrebasse@40 235 -- Set action
contrebasse@73 236 if type(btn.action)=="function" then
contrebasse@40 237 btn:SetScript("PreClick",btn.action)
contrebasse@40 238 btn:SetAttribute("type", nil)
contrebasse@40 239 btn:SetAttribute("macrotext", nil)
contrebasse@40 240 else --if type(action)=="string" then
contrebasse@40 241 btn:SetScript("PreClick",nil)
contrebasse@40 242 btn:SetAttribute("type", "macro")
contrebasse@73 243 btn:SetAttribute("macrotext", btn.action:format(btn.itemNameString))
contrebasse@40 244 end -- if
contrebasse@40 245
contrebasse@3 246 anyMakable = true
contrebasse@5 247 btn.countDetail:SetTextColor(1, 1, 1, 1)
contrebasse@3 248 btn.icon:SetVertexColor(1,1,1);
contrebasse@3 249 btn.itemName:SetTextColor(1,1,1,1)
contrebasse@3 250 else
contrebasse@5 251 -- Do not disable the button, to be able to show the tooltip
contrebasse@40 252 -- Disable only the effects
contrebasse@40 253 btn:SetScript("PreClick",WarnNotMakable)
contrebasse@40 254 btn:SetAttribute("type", nil)
contrebasse@40 255 btn:SetAttribute("macrotext", nil)
contrebasse@108 256
contrebasse@5 257 btn.countDetail:SetTextColor(1, 0.1, 0.1, 1)
contrebasse@3 258 btn.icon:SetVertexColor(0.5, 0.5, 0.5)
contrebasse@3 259 btn.itemName:SetTextColor(1,1,1,0.5)
contrebasse@3 260 end
contrebasse@5 261
contrebasse@5 262 btn.numMakable = numMakable
contrebasse@3 263 end
contrebasse@3 264
contrebasse@5 265 local r,g,b = TitleText:GetTextColor()
contrebasse@3 266 if anyMakable then
contrebasse@3 267 itemIcon:SetVertexColor(1,1,1)
contrebasse@5 268 TitleText:SetTextColor(r,g,b,1)
contrebasse@3 269 else
contrebasse@3 270 itemIcon:SetVertexColor(0.5, 0.5, 0.5)
contrebasse@5 271 TitleText:SetTextColor(r,g,b,0.7)
contrebasse@0 272 end
contrebasse@0 273 end
contrebasse@0 274
contrebasse@73 275 local function menuAddItem(action,itemID,reagent)
contrebasse@0 276 local btn
contrebasse@0 277 -- Create a button only if necessary
contrebasse@0 278 if numActiveEntries >= #menuEntries then
contrebasse@3 279 btn = createMenuEntry()
contrebasse@0 280 else
contrebasse@0 281 btn = menuEntries[numActiveEntries+1]
contrebasse@0 282 end
contrebasse@0 283
contrebasse@3 284 -- Set text and icon
contrebasse@96 285 local name, link, texture, _
contrebasse@96 286 if reagent[1] then
contrebasse@96 287 name, link, _, _, _, _, _, _, _, texture = GetItemInfo(reagent[1])
contrebasse@96 288 if not (name and link and texture) then
contrebasse@96 289 -- Will be retried on next OnUpdate
contrebasse@96 290 return
contrebasse@96 291 end
contrebasse@96 292 elseif reagent.spellLink then
contrebasse@96 293 --name, rank, icon, powerCost, isFunnel, powerType, castingTime, minRange, maxRange = GetSpellInfo(id)
contrebasse@96 294 name, _, texture = GetSpellInfo(A.link2ID(reagent.spellLink))
contrebasse@96 295 if not (name and texture) then
contrebasse@96 296 -- Will be retried on next OnUpdate
contrebasse@96 297 return
contrebasse@96 298 end
contrebasse@96 299 link = reagent.spellLink
contrebasse@3 300 end
contrebasse@96 301
contrebasse@73 302 btn.itemName:SetText(name)
contrebasse@73 303 btn.icon:SetTexture(texture)
contrebasse@3 304
contrebasse@10 305 -- Set chance to have the item or the number of items created
contrebasse@93 306 btn.resultNumber:Hide()
contrebasse@10 307 if reagent[3] then
contrebasse@10 308 if reagent[3]<1 then
contrebasse@10 309 btn.resultNumber:SetText((reagent[3]*100).."%")
contrebasse@93 310 btn.resultNumber:Show()
contrebasse@11 311 elseif reagent[4] and reagent[3]~=reagent[4] then
contrebasse@11 312 btn.resultNumber:SetText(math.min(reagent[3],reagent[4]).."-"..math.max(reagent[3],reagent[4]))
contrebasse@93 313 btn.resultNumber:Show()
contrebasse@10 314 elseif reagent[3]>1 then
contrebasse@10 315 btn.resultNumber:SetText(reagent[3])
contrebasse@93 316 btn.resultNumber:Show()
contrebasse@10 317 end
contrebasse@10 318 end
contrebasse@10 319
contrebasse@3 320 -- Save params
contrebasse@3 321 btn.itemID = itemID
contrebasse@111 322 btn.reagent = reagent
contrebasse@10 323 btn.reagentID = reagent[1]
contrebasse@5 324 btn.reagentLink = link
contrebasse@10 325 btn.reagentsForOneRecipe = reagent[2]
contrebasse@73 326 btn.spellLink = reagent.spellLink
contrebasse@40 327 btn.action = action
contrebasse@40 328 btn.itemNameString = name
contrebasse@0 329
contrebasse@3 330 btn:Show()
contrebasse@0 331
contrebasse@2 332 -- Increase the entry number
contrebasse@0 333 numActiveEntries = numActiveEntries + 1
contrebasse@34 334
contrebasse@34 335 -- Everything went well
contrebasse@34 336 return true
contrebasse@0 337 end -- function
contrebasse@3 338
contrebasse@34 339 -- Function used on OnUpdate tu update the frame if there were errors the previous time
contrebasse@34 340 local function reopen()
contrebasse@34 341 -- Release OnUpdate frame (could conflict with BAG_UPDATE)
contrebasse@34 342 MenuFrame:SetScript("OnUpdate",nil)
contrebasse@34 343
contrebasse@34 344 -- reopen
contrebasse@111 345 A.externalCraftWindow(MenuFrame.itemID,MenuFrame.reagentIndexInRecipe,MenuFrame.superItemID)
contrebasse@34 346 end
contrebasse@34 347
contrebasse@3 348 -- Fill the window and open it
contrebasse@111 349 function A.externalCraftWindow(itemID,reagentIndexInRecipe,superItemID)
contrebasse@3 350 -- Do not open during combat
contrebasse@103 351 if InCombatLockdown() then
contrebasse@108 352 A.Error(SPELL_FAILED_AFFECTING_COMBAT)
contrebasse@103 353 return
contrebasse@103 354 end
contrebasse@3 355
contrebasse@3 356 -- Save the tradeskill
contrebasse@3 357 A.currentTradeSkill = GetTradeSkillLine()
contrebasse@3 358
contrebasse@3 359 -- Close the previous menu
contrebasse@3 360 MenuFrame:Hide()
contrebasse@3 361 for i=1,numActiveEntries do
contrebasse@3 362 menuEntries[i]:Hide()
contrebasse@3 363 end
contrebasse@3 364 numActiveEntries = 0
contrebasse@3 365
contrebasse@3 366 -- Fill the info of the reagent to make
contrebasse@35 367 local name, link, quality, _, _, _, _, _, _, texture = GetItemInfo(itemID)
contrebasse@3 368 SetPortraitToTexture(itemIcon, texture)
contrebasse@3 369 TitleText:SetText(name)
contrebasse@5 370 local color = ITEM_QUALITY_COLORS[quality]
contrebasse@5 371 TitleText:SetTextColor(color.r, color.g, color.b)
contrebasse@3 372
contrebasse@20 373 -- Save vars to show the tooltip later
contrebasse@20 374 MenuFrame.reagentLink = link
contrebasse@73 375 MenuFrame.spellLink = A.isRecipeUnique(A.data[itemID]) and A.data[itemID][1].spellLink
contrebasse@33 376 MenuFrame.itemID = itemID
contrebasse@111 377 MenuFrame.reagentIndexInRecipe = reagentIndexInRecipe
contrebasse@73 378 MenuFrame.superItemID = superItemID -- optional, will be nil if not set
contrebasse@34 379
contrebasse@3 380 -- Loop over the available recipes
contrebasse@76 381 local noSkipped = true -- check if we have to reload the external frame to get all the data
contrebasse@76 382 local existsValidEntries -- check if the menu contains at least one item (cross-tradeskill problem)
contrebasse@3 383 for _,reagent in ipairs(A.data[itemID]) do
contrebasse@73 384 if reagent.macro then
contrebasse@29 385 -- Special spell
contrebasse@76 386 existsValidEntries = true
contrebasse@76 387 noSkipped = menuAddItem(reagent.macro,itemID,reagent) and noSkipped
contrebasse@29 388 else
contrebasse@76 389 -- Standard tradeskill spell
contrebasse@110 390 if not reagent.tradeskillName or reagent.tradeskillName == A.currentTradeSkill then
contrebasse@76 391 existsValidEntries = true
contrebasse@110 392 noSkipped = menuAddItem(CraftFromExternal,itemID,reagent) and noSkipped
contrebasse@76 393 end
contrebasse@29 394 end -- if
contrebasse@3 395 end -- for
contrebasse@3 396
contrebasse@76 397 -- do not show an empty menu
contrebasse@76 398 if not existsValidEntries then
contrebasse@76 399 return false
contrebasse@76 400 end
contrebasse@76 401
contrebasse@3 402 MenuFrame:SetHeight(89 + numActiveEntries*(MENU_ENTRY_HEIGHT+2))
contrebasse@3 403
contrebasse@3 404 MenuFrame:ClearAllPoints()
contrebasse@3 405 MenuFrame:SetPoint("TOPLEFT",TradeSkillFrame,"TOPRIGHT",-2,14)
contrebasse@3 406
contrebasse@40 407 -- Update counts and set actions
contrebasse@19 408 MenuFrame.updateCounts()
contrebasse@3 409
contrebasse@3 410 MenuFrame:Show()
contrebasse@34 411
contrebasse@76 412 if not noSkipped then
contrebasse@34 413 MenuFrame:SetScript("OnUpdate",reopen)
contrebasse@34 414 end
contrebasse@3 415 end