local E, L, V, P, G = unpack(ElvUI) local S = E:GetModule('Skins') local _G = _G local unpack = unpack local select = select local pairs = pairs local ipairs = ipairs local next = next local rad = rad local CreateFrame = CreateFrame local GetItemInfo = GetItemInfo local hooksecurefunc = hooksecurefunc local GetItemQualityColor = GetItemQualityColor local ITEMQUALITY_LEGENDARY = Enum.ItemQuality.Legendary or 5 local lootQuality = { ['loottab-set-itemborder-white'] = nil, -- dont show white ['loottab-set-itemborder-green'] = 2, ['loottab-set-itemborder-blue'] = 3, ['loottab-set-itemborder-purple'] = 4, ['loottab-set-itemborder-orange'] = 5, ['loottab-set-itemborder-artifact'] = 6, } local function HandleButton(btn, ...) S:HandleButton(btn, ...) if btn:GetFontString() then btn:GetFontString():SetTextColor(1, 1, 1) end end local function SkinDungeons() local b1 = _G.EncounterJournalInstanceSelectScrollFrameScrollChildInstanceButton1 if b1 and not b1.isSkinned then HandleButton(b1) b1.bgImage:SetInside() b1.bgImage:SetTexCoord(.08, .6, .08, .6) b1.bgImage:SetDrawLayer('ARTWORK') b1.isSkinned = true end for i = 1, 100 do local b = _G['EncounterJournalInstanceSelectScrollFrameinstance'..i] if b and not b.isSkinned then HandleButton(b) b.bgImage:SetInside() b.bgImage:SetTexCoord(0.08,.6,0.08,.6) b.bgImage:SetDrawLayer('ARTWORK') b.isSkinned = true end end end local function SkinBosses() local bossIndex = 1 local _, _, bossID = _G.EJ_GetEncounterInfoByIndex(bossIndex) local bossButton local encounter = _G.EncounterJournal.encounter encounter.info.instanceButton.icon:SetMask("") while bossID do bossButton = _G['EncounterJournalBossButton'..bossIndex] if bossButton and not bossButton.isSkinned then HandleButton(bossButton) bossButton.creature:ClearAllPoints() bossButton.creature:Point('TOPLEFT', 1, -4) bossButton.isSkinned = true end bossIndex = bossIndex + 1 _, _, bossID = _G.EJ_GetEncounterInfoByIndex(bossIndex) end end local function SkinOverviewInfo(self, _, index) local header = self.overviews[index] if not header.isSkinned then for i = 4, 18 do select(i, header.button:GetRegions()):SetTexture() end HandleButton(header.button) header.descriptionBG:SetAlpha(0) header.descriptionBGBottom:SetAlpha(0) header.description:SetTextColor(1, 1, 1) header.button.title:SetTextColor(unpack(E.media.rgbvaluecolor)) header.button.title.SetTextColor = E.noop header.button.expandedIcon:SetTextColor(1, 1, 1) header.button.expandedIcon.SetTextColor = E.noop header.isSkinned = true end end local function SkinOverviewInfoBullets(object) local parent = object:GetParent() if parent.Bullets then for _, bullet in pairs(parent.Bullets) do if not bullet.styled then bullet.Text:SetTextColor(1, 1, 1) bullet.styled = true end end end end local function HandleTabs(tab) tab:StripTextures() tab:SetText(tab.tooltip) tab:GetFontString():FontTemplate(nil, nil, '') tab:SetTemplate() tab:SetScript('OnEnter', E.noop) tab:SetScript('OnLeave', E.noop) tab:Size(tab:GetFontString():GetStringWidth()*1.5, 20) tab.SetPoint = E.noop end local function SkinAbilitiesInfo() local index = 1 local header = _G['EncounterJournalInfoHeader'..index] while header do if not header.isSkinned then header.flashAnim.Play = E.noop header.descriptionBG:SetAlpha(0) header.descriptionBGBottom:SetAlpha(0) for i = 4, 18 do select(i, header.button:GetRegions()):SetTexture() end header.description:SetTextColor(1, 1, 1) header.button.title:SetTextColor(unpack(E.media.rgbvaluecolor)) header.button.title.SetTextColor = E.noop header.button.expandedIcon:SetTextColor(1, 1, 1) header.button.expandedIcon.SetTextColor = E.noop HandleButton(header.button) header.button.bg = CreateFrame('Frame', nil, header.button) header.button.bg:SetTemplate() header.button.bg:SetOutside(header.button.abilityIcon) header.button.bg:SetFrameLevel(header.button.bg:GetFrameLevel() - 1) header.button.abilityIcon:SetTexCoord(.08, .92, .08, .92) header.isSkinned = true end if header.button.abilityIcon:IsShown() then header.button.bg:Show() else header.button.bg:Hide() end index = index + 1 header = _G['EncounterJournalInfoHeader'..index] end end local function HandleTopTabs(tab) S:HandleTab(tab) tab:SetHitRectInsets(0, 0, 0, 0) end local function ItemSetsItemBorder(border, atlas) local parent = border:GetParent() local backdrop = parent and parent.Icon and parent.Icon.backdrop if backdrop then local color = E.QualityColors[lootQuality[atlas]] if color then backdrop:SetBackdropBorderColor(color.r, color.g, color.b) else backdrop:SetBackdropBorderColor(unpack(E.media.bordercolor)) end end end function S:Blizzard_EncounterJournal() if not (E.private.skins.blizzard.enable and E.private.skins.blizzard.encounterjournal) then return end local EJ = _G.EncounterJournal S:HandlePortraitFrame(EJ) EJ.navBar:StripTextures(true) EJ.navBar.overlay:StripTextures(true) EJ.navBar:CreateBackdrop() EJ.navBar.backdrop:Point('TOPLEFT', -2, 0) EJ.navBar.backdrop:Point('BOTTOMRIGHT') HandleButton(EJ.navBar.home, true) EJ.navBar.home.xoffset = 1 S:HandleEditBox(EJ.searchBox) EJ.searchBox:ClearAllPoints() EJ.searchBox:Point('TOPLEFT', EJ.navBar, 'TOPRIGHT', 4, 0) local InstanceSelect = EJ.instanceSelect InstanceSelect.bg:Kill() S:HandleDropDownBox(InstanceSelect.tierDropDown) S:HandleScrollBar(InstanceSelect.scroll.ScrollBar) HandleTopTabs(InstanceSelect.suggestTab) HandleTopTabs(InstanceSelect.dungeonsTab) HandleTopTabs(InstanceSelect.raidsTab) HandleTopTabs(InstanceSelect.LootJournalTab) InstanceSelect.suggestTab:ClearAllPoints() InstanceSelect.suggestTab:Width(175) InstanceSelect.suggestTab:Point('BOTTOMLEFT', InstanceSelect, 'TOPLEFT', 2, -43) InstanceSelect.dungeonsTab:ClearAllPoints() InstanceSelect.dungeonsTab:Width(125) InstanceSelect.dungeonsTab:Point('BOTTOMLEFT', InstanceSelect.suggestTab, 'BOTTOMRIGHT', 2, 0) InstanceSelect.raidsTab:ClearAllPoints() InstanceSelect.raidsTab:Width(125) InstanceSelect.raidsTab:Point('BOTTOMLEFT', InstanceSelect.dungeonsTab, 'BOTTOMRIGHT', 2, 0) InstanceSelect.LootJournalTab:ClearAllPoints() InstanceSelect.LootJournalTab:Width(125) InstanceSelect.LootJournalTab:Point('BOTTOMLEFT', InstanceSelect.raidsTab, 'BOTTOMRIGHT', 2, 0) --Skin the tab text for i = 1, #InstanceSelect.Tabs do local tab = InstanceSelect.Tabs[i] local text = tab:GetFontString() text:FontTemplate() text:Point('CENTER') end --Encounter Info Frame local EncounterInfo = EJ.encounter.info EncounterInfo:SetTemplate('Transparent') EncounterInfo.encounterTitle:Kill() S:HandleIcon(EncounterInfo.instanceButton.icon, true) EncounterInfo.instanceButton.icon:SetTexCoord(0, 1, 0, 1) EncounterInfo.instanceButton:SetNormalTexture('') EncounterInfo.instanceButton:SetHighlightTexture('') --_G.EncounterJournalEncounterFrameInfoBG:Kill() _G.EncounterJournalEncounterFrameInfoBG:Height(385) EncounterInfo.leftShadow:Kill() EncounterInfo.rightShadow:Kill() EncounterInfo.model.dungeonBG:Kill() _G.EncounterJournalEncounterFrameInfoModelFrameShadow:Kill() EncounterInfo.instanceButton:ClearAllPoints() EncounterInfo.instanceButton:Point('TOPLEFT', EncounterInfo, 'TOPLEFT', 0, 15) EncounterInfo.instanceTitle:ClearAllPoints() EncounterInfo.instanceTitle:Point('BOTTOM', EncounterInfo.bossesScroll, 'TOP', 10, 15) _G.EncounterJournalEncounterFrameInfoLootScrollFrameClassFilterClearFrame:GetRegions():SetAlpha(0) EncounterInfo.difficulty:StripTextures() EncounterInfo.reset:StripTextures() --buttons EncounterInfo.difficulty:ClearAllPoints() EncounterInfo.difficulty:Point('BOTTOMRIGHT', _G.EncounterJournalEncounterFrameInfoBG, 'TOPRIGHT', -5, 7) HandleButton(EncounterInfo.reset) HandleButton(EncounterInfo.difficulty) HandleButton(_G.EncounterJournalEncounterFrameInfoLootScrollFrameSlotFilterToggle, true) HandleButton(_G.EncounterJournalEncounterFrameInfoLootScrollFrameFilterToggle, true) _G.EncounterJournalEncounterFrameInfoLootScrollFrameSlotFilterToggle:ClearAllPoints() _G.EncounterJournalEncounterFrameInfoLootScrollFrameSlotFilterToggle:Point('TOPLEFT', EncounterInfo, 'TOP', 0, -8) _G.EncounterJournalEncounterFrameInfoLootScrollFrameFilterToggle:ClearAllPoints() _G.EncounterJournalEncounterFrameInfoLootScrollFrameFilterToggle:Point('LEFT', _G.EncounterJournalEncounterFrameInfoLootScrollFrameSlotFilterToggle, 'RIGHT', 4, 0) EncounterInfo.reset:ClearAllPoints() EncounterInfo.reset:Point('TOPRIGHT', EncounterInfo.difficulty, 'TOPLEFT', -10, 0) _G.EncounterJournalEncounterFrameInfoResetButtonTexture:SetTexture([[Interface\EncounterJournal\UI-EncounterJournalTextures]]) _G.EncounterJournalEncounterFrameInfoResetButtonTexture:SetTexCoord(0.90625000, 0.94726563, 0.00097656, 0.02050781) S:HandleScrollBar(EncounterInfo.bossesScroll.ScrollBar) S:HandleScrollBar(_G.EncounterJournalEncounterFrameInstanceFrameLoreScrollFrameScrollBar) _G.EncounterJournalEncounterFrameInstanceFrameBG:SetScale(0.85) _G.EncounterJournalEncounterFrameInstanceFrameBG:ClearAllPoints() _G.EncounterJournalEncounterFrameInstanceFrameBG:Point('CENTER', 0, 40) _G.EncounterJournalEncounterFrameInstanceFrameTitle:ClearAllPoints() _G.EncounterJournalEncounterFrameInstanceFrameTitle:Point('TOP', 0, -105) _G.EncounterJournalEncounterFrameInstanceFrameMapButton:ClearAllPoints() _G.EncounterJournalEncounterFrameInstanceFrameMapButton:Point('LEFT', 55, -56) S:HandleScrollBar(EncounterInfo.overviewScroll.ScrollBar) S:HandleScrollBar(EncounterInfo.detailsScroll.ScrollBar) S:HandleScrollBar(EncounterInfo.lootScroll.scrollBar) EncounterInfo.detailsScroll:Height(360) EncounterInfo.lootScroll:Height(360) EncounterInfo.overviewScroll:Height(360) EncounterInfo.bossesScroll:Height(360) _G.EncounterJournalEncounterFrameInfoLootScrollFrame:Height(360) _G.EncounterJournalEncounterFrameInfoLootScrollFrame:Point('TOPLEFT', _G.EncounterJournalEncounterFrameInfoLootScrollFrame:GetParent(), 'TOP', 20, -70) _G.EncounterJournalEncounterFrameInfoLootScrollFrame:Point('BOTTOMRIGHT', _G.EncounterJournalEncounterFrameInfoLootScrollFrame:GetParent(), 'BOTTOMRIGHT', -10, 5) --Tabs local tabs = { EncounterInfo.overviewTab, EncounterInfo.lootTab, EncounterInfo.bossTab, EncounterInfo.modelTab } for i=1, #tabs do --not beautiful but eh tabs[i]:ClearAllPoints() end for i=1, #tabs do local tab = tabs[i] if i == 4 then tab:Point('TOPRIGHT', EJ, 'BOTTOMRIGHT', -10, E.PixelMode and 0 or 2) else tab:Point('RIGHT', tabs[i+1], 'LEFT', -4, 0) end HandleTabs(tab) end hooksecurefunc('EncounterJournal_SetTabEnabled', function(tab, enabled) if enabled then tab:GetFontString():SetTextColor(1, 1, 1) else tab:GetFontString():SetTextColor(0.6, 0.6, 0.6) end end) -- Loot buttons for i, items in next, EJ.encounter.info.lootScroll.buttons do local item = items.lootFrame item.bossTexture:SetAlpha(0) item.bosslessTexture:SetAlpha(0) item.icon:Size(32, 32) item.icon:Point('TOPLEFT', E.PixelMode and 3 or 4, -(E.PixelMode and 7 or 8)) item.icon:SetDrawLayer('ARTWORK') item.icon:SetTexCoord(unpack(E.TexCoords)) item.IconBackdrop = CreateFrame('Frame', nil, item) item.IconBackdrop:SetFrameLevel(item:GetFrameLevel()) item.IconBackdrop:Point('TOPLEFT', item.icon, -1, 1) item.IconBackdrop:Point('BOTTOMRIGHT', item.icon, 1, -1) item.IconBackdrop:SetTemplate() item.name:ClearAllPoints() item.name:Point('TOPLEFT', item.icon, 'TOPRIGHT', 6, -2) item.boss:ClearAllPoints() item.boss:Point('BOTTOMLEFT', 4, 6) item.slot:ClearAllPoints() item.slot:Point('TOPLEFT', item.name, 'BOTTOMLEFT', 0, -3) item.armorType:ClearAllPoints() item.armorType:Point('RIGHT', item, 'RIGHT', -10, 0) S:HandleIconBorder(item.IconBorder, item.IconBackdrop) if E.private.skins.parchmentRemoverEnable then item.boss:SetTextColor(1, 1, 1) item.slot:SetTextColor(1, 1, 1) item.armorType:SetTextColor(1, 1, 1) end if i == 1 then items:ClearAllPoints() items:Point('TOPLEFT', EncounterInfo.lootScroll.scrollChild, 10, 0) end end -- Search _G.EncounterJournalSearchResults:StripTextures() _G.EncounterJournalSearchResults:SetTemplate() _G.EncounterJournalSearchBox.searchPreviewContainer:StripTextures() S:HandleCloseButton(_G.EncounterJournalSearchResultsCloseButton) S:HandleScrollBar(_G.EncounterJournalSearchResultsScrollFrameScrollBar) --Suggestions for i = 1, _G.AJ_MAX_NUM_SUGGESTIONS do local suggestion = EJ.suggestFrame['Suggestion'..i] if i == 1 then HandleButton(suggestion.button) suggestion.button:SetFrameLevel(4) S:HandleNextPrevButton(suggestion.prevButton, nil, nil, true) S:HandleNextPrevButton(suggestion.nextButton, nil, nil, true) else HandleButton(suggestion.centerDisplay.button) end end if E.private.skins.parchmentRemoverEnable then local suggestFrame = EJ.suggestFrame -- Suggestion 1 local suggestion = suggestFrame.Suggestion1 suggestion.bg:Hide() suggestion:SetTemplate('Transparent') local centerDisplay = suggestion.centerDisplay centerDisplay.title.text:SetTextColor(1, 1, 1) centerDisplay.description.text:SetTextColor(.9, .9, .9) local reward = suggestion.reward reward.text:SetTextColor(.9, .9, .9) reward.iconRing:Hide() reward.iconRingHighlight:SetTexture() -- Suggestion 2 and 3 for i = 2, 3 do suggestion = suggestFrame['Suggestion'..i] suggestion.bg:Hide() suggestion:SetTemplate('Transparent') suggestion.icon:Point('TOPLEFT', 10, -10) centerDisplay = suggestion.centerDisplay centerDisplay:ClearAllPoints() centerDisplay:Point('TOPLEFT', 85, -10) centerDisplay.title.text:SetTextColor(1, 1, 1) centerDisplay.description.text:SetTextColor(.9, .9, .9) reward = suggestion.reward reward.iconRing:Hide() reward.iconRingHighlight:SetTexture() end hooksecurefunc('EJSuggestFrame_RefreshDisplay', function() for i, data in ipairs(suggestFrame.suggestions) do local sugg = next(data) and suggestFrame['Suggestion'..i] if sugg then if not sugg.icon.backdrop then sugg.icon:CreateBackdrop() end sugg.icon:SetMask('') sugg.icon:SetTexture(data.iconPath) sugg.icon:SetTexCoord(unpack(E.TexCoords)) sugg.iconRing:Hide() end end end) hooksecurefunc('EJSuggestFrame_UpdateRewards', function(sugg) local rewardData = sugg.reward.data if rewardData then if not sugg.reward.icon.backdrop then sugg.reward.icon:CreateBackdrop(nil, nil, nil, nil, nil, nil, nil, nil, 3) end sugg.reward.icon:SetMask('') sugg.reward.icon:SetTexture(rewardData.itemIcon or rewardData.currencyIcon or [[Interface\Icons\achievement_guildperk_mobilebanking]]) sugg.reward.icon:SetTexCoord(unpack(E.TexCoords)) local r, g, b = unpack(E.media.bordercolor) if rewardData.itemID then local quality = select(3, GetItemInfo(rewardData.itemID)) if quality and quality > 1 then r, g, b = GetItemQualityColor(quality) end end sugg.reward.icon.backdrop:SetBackdropBorderColor(r, g, b) end end) end --Suggestion Reward Tooltips if E.private.skins.blizzard.tooltip then local tooltip = _G.EncounterJournalTooltip local item1 = tooltip.Item1 local item2 = tooltip.Item2 tooltip.NineSlice:SetTemplate('Transparent') S:HandleIcon(item1.icon) S:HandleIcon(item2.icon) item1.IconBorder:Kill() item2.IconBorder:Kill() end --Powers local LJ = EJ.LootJournal HandleButton(LJ.ClassDropDownButton, true) LJ.ClassDropDownButton:SetFrameLevel(10) HandleButton(LJ.RuneforgePowerFilterDropDownButton, true) LJ.RuneforgePowerFilterDropDownButton:SetFrameLevel(10) if E.private.skins.parchmentRemoverEnable then LJ:StripTextures() LJ:SetTemplate('Transparent') end S:HandleScrollBar(LJ.PowersFrame.ScrollBar) local IconColor = E.QualityColors[ITEMQUALITY_LEGENDARY] hooksecurefunc(LJ.PowersFrame, 'RefreshListDisplay', function(buttons) if not buttons.elements then return end for i = 1, buttons:GetNumElementFrames() do local btn = buttons.elements[i] if btn and not btn.IsSkinned then btn.Background:SetAlpha(0) btn.BackgroundOverlay:SetAlpha(0) btn.CircleMask:Hide() S:HandleIcon(btn.Icon, true) btn.Icon.backdrop:SetBackdropBorderColor(IconColor.r, IconColor.g, IconColor.b) btn:CreateBackdrop('Transparent') btn.backdrop:Point('TOPLEFT', 5, -1) btn.backdrop:Point('BOTTOMRIGHT', 5, 1) btn.IsSkinned = true end end end) --Dungeon/raid selection buttons (From AddOnSkins) hooksecurefunc('EncounterJournal_ListInstances', SkinDungeons) _G.EncounterJournal_ListInstances() if E.private.skins.parchmentRemoverEnable then hooksecurefunc('EncounterJournal_DisplayInstance', SkinBosses) --Boss selection buttons hooksecurefunc('EncounterJournal_SetUpOverview', SkinOverviewInfo) --Overview Info (From Aurora) hooksecurefunc('EncounterJournal_SetBullets', SkinOverviewInfoBullets) --Overview Info Bullets (From Aurora) hooksecurefunc('EncounterJournal_ToggleHeaders', SkinAbilitiesInfo) --Abilities Info (From Aurora) _G.EncounterJournalEncounterFrameInfoBG:Kill() EncounterInfo.detailsScroll.child.description:SetTextColor(1, 1, 1) EncounterInfo.overviewScroll.child.loreDescription:SetTextColor(1, 1, 1) _G.EncounterJournalEncounterFrameInfoOverviewScrollFrameScrollChildTitle:SetTextColor(1, 1, 1) EncounterInfo.overviewScroll.child.overviewDescription.Text:SetTextColor(1, 1, 1) EJ.encounter.instance.loreScroll.child.lore:SetTextColor(1, 1, 1) _G.EncounterJournalEncounterFrameInstanceFrameBG:SetTexCoord(0.71, 0.06, 0.582, 0.08) _G.EncounterJournalEncounterFrameInstanceFrameBG:SetRotation(rad(180)) _G.EncounterJournalEncounterFrameInstanceFrameBG:SetScale(0.7) _G.EncounterJournalEncounterFrameInstanceFrameBG:CreateBackdrop() _G.EncounterJournalEncounterFrameInstanceFrame.titleBG:SetAlpha(0) _G.EncounterJournalEncounterFrameInstanceFrameTitle:SetTextColor(1, 1, 1) _G.EncounterJournalEncounterFrameInstanceFrameTitle:FontTemplate(nil, 25) _G.EncounterJournalEncounterFrameInfoOverviewScrollFrameScrollChildHeader:SetAlpha(0) local parchment = LJ:GetRegions() parchment:Kill() end local LootDropdown = _G.EncounterJournalLootJournalViewDropDown S:HandleDropDownBox(LootDropdown) LootDropdown:SetScript('OnShow', function(dd) dd:SetFrameLevel(5) -- might be able to hook a function later; hotfix builds didn't export Blizzard_LootJournalItems.xml end) do -- Item Sets local ItemSetsFrame = EJ.LootJournalItems.ItemSetsFrame HandleButton(ItemSetsFrame.ClassButton, true) S:HandleScrollBar(ItemSetsFrame.scrollBar) if E.private.skins.parchmentRemoverEnable then EJ.LootJournalItems:StripTextures() EJ.LootJournalItems:SetTemplate('Transparent') hooksecurefunc(ItemSetsFrame, 'UpdateList', function(frame) if frame.buttons then for _, button in ipairs(frame.buttons) do if button and not button.backdrop then button:CreateBackdrop('Transparent') button.Background:Hide() end end end end) end hooksecurefunc(ItemSetsFrame, 'ConfigureItemButton', function(_, button) if not button.Icon then return end if not button.Icon.backdrop then S:HandleIcon(button.Icon, true) end if button.Border and not button.Border.isSkinned then button.Border:SetAlpha(0) ItemSetsItemBorder(button.Border, button.Border:GetAtlas()) -- handle first one hooksecurefunc(button.Border, 'SetAtlas', ItemSetsItemBorder) button.Border.isSkinned = true end end) end end S:AddCallbackForAddon('Blizzard_EncounterJournal')