You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

2784 lines
95 KiB

local GlobalAddonName, MRT = ...
local VMRT = nil
local module = MRT:New("Note",MRT.L.message)
local ELib,L = MRT.lib,MRT.L
local GetTime, GetSpecializationInfo = GetTime, GetSpecializationInfo
local string_gsub, strsplit, tonumber, format, string_match, floor, string_find, type, string_gmatch = string.gsub, strsplit, tonumber, format, string.match, floor, string.find, type, string.gmatch
local GetSpecialization = GetSpecialization
if MRT.isClassic then
GetSpecialization = MRT.NULLfunc
end
module.db.otherIconsList = {
{"{"..L.classLocalizate["WARRIOR"] .."}",crop=":16:16:0:0:256:256:0:64:0:64","Interface\\GLUES\\CHARACTERCREATE\\UI-CHARACTERCREATE-CLASSES",0,0.25,0,0.25},
{"{"..L.classLocalizate["PALADIN"] .."}",crop=":16:16:0:0:256:256:0:64:128:192","Interface\\GLUES\\CHARACTERCREATE\\UI-CHARACTERCREATE-CLASSES",0,0.25,0.5,0.75},
{"{"..L.classLocalizate["HUNTER"] .."}",crop=":16:16:0:0:256:256:0:64:64:128","Interface\\GLUES\\CHARACTERCREATE\\UI-CHARACTERCREATE-CLASSES",0,0.25,0.25,0.5},
{"{"..L.classLocalizate["ROGUE"] .."}",crop=":16:16:0:0:256:256:127:190:0:64","Interface\\GLUES\\CHARACTERCREATE\\UI-CHARACTERCREATE-CLASSES",0.49609375,0.7421875,0,0.25},
{"{"..L.classLocalizate["PRIEST"] .."}",crop=":16:16:0:0:256:256:127:190:64:128","Interface\\GLUES\\CHARACTERCREATE\\UI-CHARACTERCREATE-CLASSES",0.49609375,0.7421875,0.25,0.5},
{"{"..L.classLocalizate["DEATHKNIGHT"] .."}",crop=":16:16:0:0:256:256:64:128:128:192","Interface\\GLUES\\CHARACTERCREATE\\UI-CHARACTERCREATE-CLASSES",0.25,0.5,0.5,0.75},
{"{"..L.classLocalizate["SHAMAN"] .."}",crop=":16:16:0:0:256:256:64:127:64:128","Interface\\GLUES\\CHARACTERCREATE\\UI-CHARACTERCREATE-CLASSES",0.25,0.49609375,0.25,0.5},
{"{"..L.classLocalizate["MAGE"] .."}",crop=":16:16:0:0:256:256:64:127:0:64","Interface\\GLUES\\CHARACTERCREATE\\UI-CHARACTERCREATE-CLASSES",0.25,0.49609375,0,0.25},
{"{"..L.classLocalizate["WARLOCK"] .."}",crop=":16:16:0:0:256:256:190:253:64:128","Interface\\GLUES\\CHARACTERCREATE\\UI-CHARACTERCREATE-CLASSES",0.7421875,0.98828125,0.25,0.5},
{"{"..L.classLocalizate["MONK"] .."}",crop=":16:16:0:0:256:256:128:189:128:192","Interface\\GLUES\\CHARACTERCREATE\\UI-CHARACTERCREATE-CLASSES",0.5,0.73828125,0.5,0.75},
{"{"..L.classLocalizate["DRUID"] .."}",crop=":16:16:0:0:256:256:190:253:0:64","Interface\\GLUES\\CHARACTERCREATE\\UI-CHARACTERCREATE-CLASSES",0.7421875,0.98828125,0,0.25},
{"{"..L.classLocalizate["DEMONHUNTER"] .."}",crop=":16:16:0:0:256:256:190:253:128:192","Interface\\GLUES\\CHARACTERCREATE\\UI-CHARACTERCREATE-CLASSES",0.7421875,0.98828125,0.5,0.75},
{"{wow}","Interface\\FriendsFrame\\Battlenet-WoWicon"},
{"{d3}","Interface\\FriendsFrame\\Battlenet-D3icon"},
{"{sc2}","Interface\\FriendsFrame\\Battlenet-Sc2icon"},
{"{bnet}","Interface\\FriendsFrame\\Battlenet-Portrait"},
{"{bnet1}","Interface\\FriendsFrame\\Battlenet-Battleneticon"},
{"{alliance}","Interface\\FriendsFrame\\PlusManz-Alliance"},
{"{horde}","Interface\\FriendsFrame\\PlusManz-Horde"},
{"{hots}","Interface\\FriendsFrame\\Battlenet-HotSicon"},
{"{ow}","Interface\\FriendsFrame\\Battlenet-Overwatchicon"},
{"{sc1}","Interface\\FriendsFrame\\Battlenet-SCicon"},
{"{barcade}","Interface\\FriendsFrame\\Battlenet-BlizzardArcadeCollectionicon"},
{"{crashb}","Interface\\FriendsFrame\\Battlenet-CrashBandicoot4icon"},
{"{tank}",path="Interface\\LFGFrame\\UI-LFG-ICON-PORTRAITROLES",crop=":16:16:0:0:64:64:0:19:22:41","Interface\\LFGFrame\\UI-LFG-ICON-ROLES",0,0.26171875,0.26171875,0.5234375},
{"{healer}",path="Interface\\LFGFrame\\UI-LFG-ICON-PORTRAITROLES",crop=":16:16:0:0:64:64:20:39:1:20","Interface\\LFGFrame\\UI-LFG-ICON-ROLES",0.26171875,0.5234375,0,0.26171875},
{"{dps}",path="Interface\\LFGFrame\\UI-LFG-ICON-PORTRAITROLES",crop=":16:16:0:0:64:64:20:39:22:41","Interface\\LFGFrame\\UI-LFG-ICON-ROLES",0.26171875,0.5234375,0.26171875,0.5234375},
}
if MRT.isClassic then
tremove(module.db.otherIconsList,12)
tremove(module.db.otherIconsList,10)
3 years ago
if not MRT.isLK then tremove(module.db.otherIconsList,6) end
end
if MRT.is10 then
tinsert(module.db.otherIconsList,13,{"{"..L.classLocalizate["EVOKER"] .."}","interface/icons/classicon_evoker"})
end
module.db.iconsLocalizatedNames = {
L.raidtargeticon1,L.raidtargeticon2,L.raidtargeticon3,L.raidtargeticon4,L.raidtargeticon5,L.raidtargeticon6,L.raidtargeticon7,L.raidtargeticon8,
}
local iconsLangs = {"eng","de","it","fr","ru","es","pt"}
for _,lang in pairs(iconsLangs) do
local new = {}
module.db["icons"..lang.."Names"] = new
for i=1,8 do
new[i] = L["raidtargeticon"..i.."_"..lang]
end
end
local frameStrataList = {"BACKGROUND","LOW","MEDIUM","HIGH","DIALOG","FULLSCREEN","FULLSCREEN_DIALOG","TOOLTIP"}
module.db.msgindex = -1
module.db.lasttext = ""
module.db.encounter_time_p = {} --phases
module.db.encounter_time_c = {} --custom
module.db.encounter_time_wa_uids = {} --wa custom events
module.db.encounter_id = {}
local encounter_time_p = module.db.encounter_time_p
local encounter_time_c = module.db.encounter_time_c
local encounter_time_wa_uids = module.db.encounter_time_wa_uids
local encounter_id = module.db.encounter_id
local predefSpellIcons = { --some talents can replace icons for basic spells
[47536] = 237548,
[1022] = 135964,
}
local function GSUB_Icon(spellID,iconSize)
spellID = tonumber(spellID)
if not iconSize or iconSize == "" then
iconSize = 16
else
iconSize = min(tonumber(iconSize),40)
end
local preicon = predefSpellIcons[spellID]
if preicon then
return "|T"..preicon..":"..iconSize.."|t"
end
local spellTexture = select(3,GetSpellInfo(spellID))
return "|T"..(spellTexture or "Interface\\Icons\\INV_MISC_QUESTIONMARK")..":"..iconSize.."|t"
end
local function GSUB_Player(anti,list,msg)
list = {strsplit(",",list)}
local found = false
local myName = (MRT.SDB.charName):lower()
for i=1,#list do
list[i] = list[i]:gsub("|?|c........",""):gsub("|?|r",""):lower()
if strsplit("-",list[i]) == myName then
found = true
break
end
end
if (found and anti == "") or (not found and anti == "!") then
return msg
else
return ""
end
end
local function GSUB_Encounter(list,msg)
list = {strsplit(",",list)}
local found = false
for i=1,#list do
list[i] = list[i]:gsub("|?|c........",""):gsub("|?|r",""):lower()
if encounter_id[ list[i] ] then
found = true
break
end
end
if found then
return msg
else
return ""
end
end
local classList = {
[L.classLocalizate.WARRIOR:lower()] = 1,
[L.classLocalizate.PALADIN:lower()] = 2,
[L.classLocalizate.HUNTER:lower()] = 3,
[L.classLocalizate.ROGUE:lower()] = 4,
[L.classLocalizate.PRIEST:lower()] = 5,
[L.classLocalizate.DEATHKNIGHT:lower()] = 6,
[L.classLocalizate.SHAMAN:lower()] = 7,
[L.classLocalizate.MAGE:lower()] = 8,
[L.classLocalizate.WARLOCK:lower()] = 9,
[L.classLocalizate.MONK:lower()] = 10,
[L.classLocalizate.DRUID:lower()] = 11,
[L.classLocalizate.DEMONHUNTER:lower()] = 12,
[L.classLocalizate.EVOKER:lower()] = 13,
["warrior"] = 1,
["paladin"] = 2,
["hunter"] = 3,
["rogue"] = 4,
["priest"] = 5,
["deathknight"] = 6,
["shaman"] = 7,
["mage"] = 8,
["warlock"] = 9,
["monk"] = 10,
["druid"] = 11,
["demonhunter"] = 12,
["evoker"] = 13,
["war"] = 1,
["pal"] = 2,
["hun"] = 3,
["rog"] = 4,
["pri"] = 5,
["dk"] = 6,
["sham"] = 7,
["lock"] = 9,
["dru"] = 11,
["dh"] = 12,
["dragon"] = 13,
["1"] = 1,
["2"] = 2,
["3"] = 3,
["4"] = 4,
["5"] = 5,
["6"] = 6,
["7"] = 7,
["8"] = 7,
["9"] = 9,
["10"] = 10,
["11"] = 11,
["12"] = 12,
["13"] = 13,
}
local function GSUB_Class(anti,list,msg)
list = {strsplit(",",list)}
local myClassIndex = select(3,UnitClass("player"))
local found = false
for i=1,#list do
list[i] = list[i]:gsub("|?|c........",""):gsub("|?|r",""):lower()
if classList[ list[i] ] == myClassIndex then
found = true
break
end
end
if (found and anti == "") or (not found and anti == "!") then
return msg
else
return ""
end
end
local function GSUB_ClassUnique(list,msg)
list = {strsplit(",",list)}
local classInParty = {}
for _, name, subgroup, class, guid, rank, level, online, isDead, combatRole in MRT.F.IterateRoster, MRT.F.GetRaidDiffMaxGroup() do
if class then
classInParty[ classList[class:lower()] or 0 ] = true
end
end
local found = nil
for i=1,#list do
list[i] = list[i]:gsub("|?|c........",""):gsub("|?|r",""):lower()
local classID = classList[ list[i] ]
if classID and classInParty[classID] then
found = classID
break
end
end
local myClassIndex = select(3,UnitClass("player"))
if found == myClassIndex then
found = true
else
found = false
end
if found then
return msg
else
return ""
end
end
local function GSUB_Race(anti,list,msg)
list = {strsplit(",",list)}
local myRace = select(2,UnitRace("player")):lower()
local found = false
for i=1,#list do
list[i] = list[i]:gsub("|?|c........",""):gsub("|?|r",""):lower()
if list[i] == myRace then
found = true
break
end
end
if (found and anti == "") or (not found and anti == "!") then
return msg
else
return ""
end
end
local function GSUB_Group(anti,groups,msg)
local myGroup = 1
if IsInRaid() then
for i=1,GetNumGroupMembers() do
local name, _, subgroup = GetRaidRosterInfo(i)
if name == MRT.SDB.charName then
myGroup = subgroup
break
end
end
end
myGroup = tostring(myGroup)
local found = groups:find(myGroup)
if (found and anti == "") or (not found and anti == "!") then
return msg
else
return ""
end
end
--[[
formats:
{time:75}
{time:1:15}
{time:2:30,p2} --start on phase 2, works only with bigwigs
{time:0:30,SCC:17:2} --start on combat log event. format "event:spellID:counter", events: SCC (SPELL_CAST_SUCCESS), SCS (SPELL_CAST_START), SAA (SPELL_AURA_APPLIED), SAR (SPELL_AURA_REMOVED)
{time:0:30,e,customevent} --start on MRT.F.Note_Timer(customevent) function or "/rt note starttimer customevent"
{time:2:30,wa:nzoth_hs1} --run weakauras custom event MRT_NOTE_TIME_EVENT with arg1 = nzoth_hs1, arg2 = time left (event runs every second when timer has 5 seconds or lower), arg3 = note line text
]]
local function GSUB_Time(preText,t,msg,newlinesym)
local timeText, opts = strsplit(",", t, 2)
local time = tonumber(timeText)
if not time then
local min, sec = strsplit(":", timeText)
if min and sec then
time = (tonumber(min) or 0) * 60 + (tonumber(sec) or 0)
else
time = -1
end
end
local prefixText
local anyType
local now = GetTime()
local waEventID
local addGlow
4 years ago
local isAllParam
local optNow
while opts do
optNow, opts = strsplit(",", opts, 2)
if optNow == "e" then
if opts then
optNow, opts = strsplit(",", opts, 2)
else
optNow = nil
end
if optNow then
local customEventStart = encounter_time_c[optNow]
if customEventStart then
time = customEventStart + time - now
--prefixText = "C "
anyType = 1
else
anyType = 2
end
end
elseif optNow:sub(1,1) == "p" then
local isGlobalPhase,phase = optNow:match("^p(g?):?(.-)$")
if phase and phase ~= "" then
local prefixText = "P"..phase.." "
local phaseStart = encounter_time_p[(isGlobalPhase == "g" and "g" or "")..phase]
if phaseStart then
time = phaseStart + time - now
anyType = 1
else
anyType = 2
end
end
elseif optNow == "glow" then
addGlow = 1
elseif optNow == "glowall" then
addGlow = 2
4 years ago
isAllParam = true
elseif optNow == "all" then
isAllParam = true
else
local prefix, arg1 = strsplit(":", optNow, 2)
if prefix == "wa" then
waEventID = (waEventID and waEventID.."," or "")..arg1
elseif prefix == "SCC" or prefix == "SCS" or prefix == "SAA" or prefix == "SAR" then
local eventStart = module.db.encounter_counters_time[optNow]
if eventStart then
time = eventStart + time - now
--prefixText = "E "
anyType = 1
else
anyType = 2
end
end
end
end
if not anyType and module.db.encounter_time then
time = module.db.encounter_time + time - now
end
if waEventID and time <= 20 and type(WeakAuras)=="table" and ((module.db.encounter_time and not anyType) or anyType == 1) then
local timeleft = time < 0 and 0 or ceil(time)
if timeleft <= 5 or timeleft % 5 == 0 then
for waEventIDnow in string_gmatch(waEventID, "[^,]+") do
local wa_event_uid_cache = waEventIDnow..":"..timeleft..":"..preText..t..msg..newlinesym
if not encounter_time_wa_uids[wa_event_uid_cache] then
encounter_time_wa_uids[wa_event_uid_cache] = true
if WeakAuras.ScanEvents and type(WeakAuras.ScanEvents)=="function" then
WeakAuras.ScanEvents("EXRT_NOTE_TIME_EVENT",waEventIDnow,timeleft,msg)
WeakAuras.ScanEvents("MRT_NOTE_TIME_EVENT",waEventIDnow,timeleft,msg)
end
end
end
end
end
3 years ago
if not msg:find(MRT.SDB.charName) and not msg:find("{everyone}") and VMRT.Note.TimerOnlyMy and not isAllParam then
4 years ago
return ""
end
if time > 10 or not module.db.encounter_time or anyType == 2 then
return preText.."|cffffed88"..(prefixText or "")..format("%d:%02d|r ",floor(time/60),time % 60)..msg..newlinesym
elseif time < 0 then
if VMRT.Note.TimerPassedHide then
return ""
else
return preText.."|cff555555"..(prefixText or "")..msg:gsub("|c........",""):gsub("|r","").."|r"..newlinesym
end
else
if time <= 5 and ((msg:find(MRT.SDB.charName) and (VMRT.Note.TimerGlow or addGlow == 1)) or (addGlow == 2)) then
module.db.glowStatus = true
end
return preText.."|cff00ff00"..(prefixText or "")..format("%d:%02d ",floor(time/60),time % 60)..msg:gsub("|c........",""):gsub("|r",""):gsub(MRT.SDB.charName,"|r|cffff0000>%1<|r|cff00ff00").."|r"..newlinesym
end
end
local function GSUB_Phase(anti,phase,msg)
if not module.db.encounter_time then
return msg
else
local isPhase
local phaseNum = tonumber(phase)
if phaseNum then
isPhase = encounter_time_p[phase]
elseif phase:sub(1,1) == "," then
local cond1,cond2 = strsplit(",",phase:sub(2),nil)
isPhase = cond1 and module.db.encounter_counters_time[cond1] and (not cond2 or not module.db.encounter_counters_time[cond2])
else
isPhase = encounter_time_p[phase]
end
if (isPhase and anti == "") or (not isPhase and anti == "!") then
return msg
else
return ""
end
end
end
3 years ago
local allIcons = {
["everyone"] = "",
}
for i=1,8 do
local icon = "|TInterface\\TargetingFrame\\UI-RaidTargetingIcon_"..i..":0|t"
allIcons[ module.db.iconsLocalizatedNames[i] ] = icon
allIcons[ "{rt"..i.."}" ] = icon
for _,lang in pairs(iconsLangs) do
allIcons[ module.db["icons"..lang.."Names"][i] ] = icon
end
end
for i=1,#module.db.otherIconsList do
local iconData = module.db.otherIconsList[i]
allIcons[ iconData[1] ] = "|T"..(iconData.path or iconData[2])..(iconData.crop or ":16").."|t"
end
local function GSUB_RaidIcon(text)
return allIcons[text]
end
local GSUB_AutoColor_Data = {}
local function GSUB_AutoColorCreate()
wipe(GSUB_AutoColor_Data)
for _, name, subgroup, class, guid, rank, level, online, isDead, combatRole in MRT.F.IterateRoster, MRT.F.GetRaidDiffMaxGroup() do
if class and name then
class = MRT.F.classColor(class)
GSUB_AutoColor_Data[ name ] = "|c"..class..name.."|r"
name = strsplit("-",name)
GSUB_AutoColor_Data[ name ] = "|c"..class..name.."|r"
end
end
end
local function GSUB_AutoColor(text)
return GSUB_AutoColor_Data[text]
end
local txtWithIcons
do
local preTimerText
txtWithIcons = function(t, onlyTimerUpdate)
if not onlyTimerUpdate or not preTimerText then
t = t or ""
if t:find("{self}") then
t = string_gsub(t,"{self}",VMRT.Note.SelfText or "")
else
t = t..(t~="" and t~=" " and "\n" or "")..(VMRT.Note.SelfText or "")
end
local spec = GetSpecialization()
if spec then
local role = select(5,GetSpecializationInfo(spec))
if role ~= "HEALER" then t = string_gsub(t,"{[Hh]}.-{/[Hh]}","") end
if role ~= "TANK" then t = string_gsub(t,"{[Tt]}.-{/[Tt]}","") end
if role ~= "DAMAGER" then t = string_gsub(t,"{[Dd]}.-{/[Dd]}","") end
end
t = t:gsub("{0}.-{/0}","")
:gsub("(\n{!?[CcPpGg]:?[^}]+})\n","%1")
:gsub("\n({/[CcPpGg]}\n)","%1")
:gsub("{(!?)[Pp]:([^}]+)}(.-){/[Pp]}",GSUB_Player)
:gsub("{(!?)[Cc]:([^}]+)}(.-){/[Cc]}",GSUB_Class)
:gsub("{[Cc][Ll][Aa][Ss][Ss][Uu][Nn][Ii][Qq][Uu][Ee]:([^}]+)}(.-){/[Cc][Ll][Aa][Ss][Ss][Uu][Nn][Ii][Qq][Uu][Ee]}",GSUB_ClassUnique)
:gsub("{(!?)[Gg](%d+)}(.-){/[Gg]}",GSUB_Group)
:gsub("{(!?)[Rr][Aa][Cc][Ee]:([^}]+)}(.-){/[Rr][Aa][Cc][Ee]}",GSUB_Race)
:gsub("{[Ee]:([^}]+)}(.-){/[Ee]}",GSUB_Encounter)
:gsub("{(!?)[Pp]([^}:][^}]*)}(.-){/[Pp]}",GSUB_Phase)
:gsub("{icon:([^}]+)}","|T%1:16|t")
:gsub("{spell:(%d+):?(%d*)}",GSUB_Icon)
4 years ago
--:gsub("%b{}",GSUB_RaidIcon)
:gsub("%b{}",allIcons)
:gsub("||([cr])","|%1")
4 years ago
--:gsub("[^ \n,]+",GSUB_AutoColor)
:gsub("[^ \n,%(%)%[%]_%$#@!&]+",GSUB_AutoColor_Data)
:gsub("\n+$", "")
preTimerText = t
else
t = preTimerText
end
return t:gsub("([^\n]*){time:([0-9:%.]+[^{}]*)}([^\n]*)(\n?)",GSUB_Time)
:gsub("%b{}",""), nil
end
end
function module.options:Load()
self:CreateTilte()
module.db.otherIconsAdditionalList = MRT.isClassic and {} or {
31821,62618,97462,98008,115310,64843,740,265202,108280,31884,196718,15286,64901,47536,246287,109964,33891,16191,108281,114049,51052,359816,363534,322118,325197,124974,197721,0,
47788,33206,6940,102342,114030,1022,116849,633,204018,207399,370960,357170,370537,0,
2825,32182,80353,0,
106898,192077,46968,119381,179057,192058,30283,0,
29166,32375,114018,108199,49576,116844,0,
0,
407069,408367,402461,406530,404744,407517,403326,400430,401319,408147,410511,407196,404789,0,
413342,409320,409328,402617,404896,408717,407640,406780,409299,409385,405704,406783,405914,403101,408193,405641,405016,405645,403699,403459,405437,408714,401809,403203,404732,408095,405083,0,
410635,407302,408476,406305,406358,405042,405391,407617,406227,404713,405375,405492,404472,0,
404445,408204,407547,406160,405827,405316,406161,406851,405821,403543,407597,401419,410690,410070,400777,407641,405828,406165,410075,406333,0,
404616,406585,397386,404687,410740,398938,400450,409696,406976,401381,409359,409271,410351,401258,410535,397383,407017,401866,401108,401401,408620,0,
409462,405956,404955,405462,405886,404942,404007,403978,406202,409942,405592,0,
402989,413351,403740,403103,401348,409093,412078,407879,408358,411182,403671,408839,0,
402120,409313,407221,409058,407919,401022,404068,407917,403908,409598,407856,407039,402831,409876,407036,403057,403049,402902,401825,410972,410953,0,
401215,402050,401500,404288,402052,403517,411030,402746,411236,403771,411238,411302,411224,404027,404705,404154,404769,401383,401525,404754,405022,401951,406428,403625,404456,401718,401905,401810,413070,406989,407576,403497,404269,404300,401340,401642,403319,401325,404218,0,
0,
370615,370649,370597,393780,396094,396023,394917,396031,373088,394904,396022,390715,0,
382458,386400,381315,376279,383073,394347,377166,378861,380487,388393,391322,381576,396351,0,
386440,371591,372315,372394,372027,371836,372275,386289,396328,386370,372056,386375,0,
373817,374112,372539,372051,372648,372129,372044,372045,372030,371976,372736,372055,373559,371983,371979,373027,396795,373405,372082,388016,0,
375580,390449,384273,384637,376851,388410,375424,376943,387627,391717,388302,387849,387943,388562,391686,385812,0,
374881,372456,376063,377780,375828,395894,393296,374916,374554,374917,396243,374918,374620,391268,374022,374621,374779,373678,391019,393429,372514,390548,382563,375792,374623,374705,374217,374485,375824,374321,372517,391055,375825,393309,371971,390920,374861,0,
376266,375871,390573,376073,388644,375485,375842,396265,388918,388716,375879,390561,375630,375653,375829,378782,375457,378787,390710,375575,375809,376257,392193,375870,375475,375716,396649,0,
388635,388643,377322,386410,377662,395929,381615,381251,382530,392086,394583,377594,377658,391281,385182,388631,385574,387261,390763,394584,391989,388431,389214,385068,385541,394582,385560,391285,388115,376126,377467,377612,0,
}
4 years ago
if MRT.isBC then
module.db.otherIconsAdditionalList = {
26983,2825,32182,16190,0,0,
38219,38215,36459,38246,37478,37138,37675,37640,37641,38441,38445,37764,38316,38310,38509,38280,0,
34172,25778,34162,39329,42783,11829,36834,36815,34480,30225,37027,36723,35879,"135188","135507","135379","132455","133528","135682","134976",0,
}
end
function self:DebugGetIcons(bossCount,notUseJJBox)
local L,U,F,C,P
function F(eID)
local f=select(4,EJ_GetEncounterInfoByIndex(eID))
repeat
local I=C_EncounterJournal.GetSectionInfo(f)
local O=I and (I.headerType == 3)
if O then
f=I.siblingSectionID
end
until not O
return f
end
function C(f)
local I=C_EncounterJournal.GetSectionInfo(f)
if I.firstChildSectionID then
C(I.firstChildSectionID)
end
if I.spellID and I.spellID~=0 and P(I.spellID) then
L[I.spellID]=true
end
if I.siblingSectionID then
C(I.siblingSectionID)
end
end
function P(s)
local i=GetSpellTexture(s)
if not U[i] then
U[i]=1
return true
end
end
local i = 1
while i <= bossCount do
L,U={},{}
local f=F(i)
C(f)
local s=""
for q,w in pairs(L)do
s=s..q..","
end
print(s..'0,')
if not notUseJJBox then
JJBox(s..'0,')
else
RES = (RES or "")..s.."0,\n"
end
i = i + 1
end
if notUseJJBox then
GMRT.F:Export2(RES)
end
end
--/run GMRT.A.Note.options:DebugGetIcons(8,true)
if not MRT.isClassic then
module.db.encountersList = MRT.F.GetEncountersList(true,false,true)
tinsert(module.db.encountersList,MRT.F.table_find(module.db.encountersList,1582,1) or #module.db.encountersList,{EXPANSION_NAME8..": "..DUNGEONS,-1182,-1183,-1184,-1185,-1186,-1187,-1188,-1189})
tinsert(module.db.encountersList,MRT.F.table_find(module.db.encountersList,909,1) or #module.db.encountersList,{EXPANSION_NAME7..": "..DUNGEONS,-1012,-968,-1041,-1022,-1030,-1023,-1002,-1001,-1036,-1021})
else
module.db.encountersList = {}
end
module.db.mapToEncounter = {
--BfD
[1358] = {2265,2263,2266},
[1352] = {2276,2280},
[1353] = 2271,
[1354] = 2268,
[1357] = 2272,
[1364] = 2281,
--Uldir
[1148] = 2144,
[1149] = 2141,
[1151] = 2136,
[1153] = 2128,
[1152] = 2134,
[1154] = {2145,2135},
[1155] = 2122,
--5ppl
[1010] = -1012,
[934] = -968, [935] = -968,
[1004] = -1041,
[1041] = -1022, [1042] = -1022,
[1038] = -1030, [1043] = -1030,
[1162] = -1023,
[974] = -1002, [975] = -1002, [974] = -1002, [975] = -1002, [976] = -1002, [977] = -1002, [978] = -1002, [979] = -1002, [980] = -1002,
[936] = -1001,
[1039] = -1036, [1040] = -1036,
[1015] = -1021, [1016] = -1021, [1017] = -1021, [1018] = -1021, [1029] = -1021,
--nyalotha
[1581] = {2329,2327,2334},
[1592] = 2328,
[1593] = 2336,
[1590] = 2333,
[1591] = 2331,
[1594] = 2335,
[1595] = 2343,
[1596] = 2345,
[1597] = {2337,2344},
--5ppl
[1666] = -1182, [1667] = -1182, [1668] = -1182,
[1674] = -1183, [1697] = -1183,
[1669] = -1184,
[1663] = -1185, [1664] = -1185, [1665] = -1185,
[1693] = -1186, [1694] = -1186, [1695] = -1186,
[1683] = -1187, [1684] = -1187, [1685] = -1187, [1687] = -1187,
[1677] = -1188, [1678] = -1188, [1679] = -1188, [1680] = -1188,
[1675] = -1189, [1676] = -1189,
--nathria
[1735] = {2398,2418,2383,2399},
[1744] = 2406,
[1745] = 2405,
[1746] = 2402,
[1747] = {2417,2407},
[1748] = 2407,
[1750] = 2412,
4 years ago
--sod
[1998] = 2423,
[1999] = {2433,2429},
[2000] = {2432,2434,2430},
[2001] = {2436,2431,2422},
[2002] = 2435,
--sotfo
[2047] = 2512,
[2048] = 2540,
[2049] = {2544,2539},
[2061] = {2542,2553,2529},
[2050] = 2546,
[2052] = {2543,2549},
[2051] = 2537,
--a
[2166] = {2688,2693,2680,2689,2683},
[2167] = 2687,
[2168] = 2682,
[2169] = 2684,
[2170] = 2685,
}
function self:GetBossName(bossID)
return bossID < 0 and L.EJInstanceName[ -bossID ] or L.bossName[ bossID ]
end
local BlackNoteNow = nil
local NoteIsSelfNow = nil
self.IsMainNoteNow = true
self.decorationLine = ELib:DecorationLine(self,true,"BACKGROUND",-5):Point("TOPLEFT",self,0,-16):Point("BOTTOMRIGHT",self,"TOPRIGHT",0,-36)
self.tab = ELib:Tabs(self,0,L.message,L.minimapmenuset,HELP_LABEL):Point(0,-36):Size(850,598):SetTo(1)
self.tab:SetBackdropBorderColor(0,0,0,0)
self.tab:SetBackdropColor(0,0,0,0)
self.tab.tabs[1]:SetPoint("TOPLEFT",0,20)
ELib:DecorationLine(self.tab.tabs[1]):Point("TOPLEFT",0,-129):Point("BOTTOMRIGHT",'x',"TOPRIGHT",0,-130)
self.NotesList = ELib:ScrollList(self.tab.tabs[1]):Size(230,467+20):Point(0,-131):AddDrag():HideBorders()
self.NotesList.selected = 1
self.NotesList.LINE_PADDING_LEFT = 2
self.NotesList.SCROLL_WIDTH = 12
self.NotesList.Frame.ScrollBar:Size(10,0):Point("TOPRIGHT",0,0):Point("BOTTOMRIGHT",0,0)
self.NotesList.Frame.ScrollBar.buttonUP:HideBorders()
self.NotesList.Frame.ScrollBar.buttonDown:HideBorders()
ELib:DecorationLine(self.NotesList.Frame.ScrollBar):Point("TOPLEFT",-1,1):Point("BOTTOMRIGHT",'x',"BOTTOMLEFT",0,0)
ELib:DecorationLine(self.tab.tabs[1]):Point("TOPLEFT",self.NotesList,"TOPRIGHT",0,1):Point("BOTTOMLEFT",self,"BOTTOM",0,0):Size(1,0)
local function SwapBlackNotes(noteFrom,noteTo)
if noteTo < 1 or noteFrom < 1 or noteTo > #VMRT.Note.Black or noteFrom > #VMRT.Note.Black or not VMRT.Note.Black[noteTo] or not VMRT.Note.Black[noteFrom] then
return
end
local text = VMRT.Note.Black[noteTo]
local title = VMRT.Note.BlackNames[noteTo]
local boss = VMRT.Note.AutoLoad[noteTo]
local lastUpdateName = VMRT.Note.BlackLastUpdateName[noteTo]
local lastUpdateTime = VMRT.Note.BlackLastUpdateTime[noteTo]
VMRT.Note.Black[noteTo] = VMRT.Note.Black[noteFrom]
VMRT.Note.BlackNames[noteTo] = VMRT.Note.BlackNames[noteFrom]
VMRT.Note.AutoLoad[noteTo] = VMRT.Note.AutoLoad[noteFrom]
VMRT.Note.BlackLastUpdateName[noteTo] = VMRT.Note.BlackLastUpdateName[noteFrom]
VMRT.Note.BlackLastUpdateTime[noteTo] = VMRT.Note.BlackLastUpdateTime[noteFrom]
VMRT.Note.Black[noteFrom] = text
VMRT.Note.BlackNames[noteFrom] = title
VMRT.Note.AutoLoad[noteFrom] = boss
VMRT.Note.BlackLastUpdateName[noteFrom] = lastUpdateName
VMRT.Note.BlackLastUpdateTime[noteFrom] = lastUpdateTime
module.options:NotesListUpdateNames()
module.options.NotesList.selected = noteTo + 2
module.options.NotesList:Update()
end
self.NotesList.ButtonMoveUp = CreateFrame("Button",nil,self.NotesList)
self.NotesList.ButtonMoveUp:Hide()
self.NotesList.ButtonMoveUp:SetSize(8,8)
self.NotesList.ButtonMoveUp:SetScript("OnClick",function(self)
SwapBlackNotes(self.index,self.index - 1)
end)
self.NotesList.ButtonMoveUp.i = self.NotesList.ButtonMoveUp:CreateTexture()
self.NotesList.ButtonMoveUp.i:SetPoint("CENTER")
self.NotesList.ButtonMoveUp.i:SetSize(16,16)
self.NotesList.ButtonMoveUp.i:SetTexture("Interface\\AddOns\\"..GlobalAddonName.."\\media\\DiesalGUIcons16x256x128")
self.NotesList.ButtonMoveUp.i:SetTexCoord(0.25,0.3125,0.625,0.5)
self.NotesList.ButtonMoveDown = CreateFrame("Button",nil,self.NotesList)
self.NotesList.ButtonMoveDown:Hide()
self.NotesList.ButtonMoveDown:SetSize(8,8)
self.NotesList.ButtonMoveDown:SetScript("OnClick",function(self)
SwapBlackNotes(self.index,self.index + 1)
end)
self.NotesList.ButtonMoveDown.i = self.NotesList.ButtonMoveDown:CreateTexture()
self.NotesList.ButtonMoveDown.i:SetPoint("CENTER")
self.NotesList.ButtonMoveDown.i:SetSize(16,16)
self.NotesList.ButtonMoveDown.i:SetTexture("Interface\\AddOns\\"..GlobalAddonName.."\\media\\DiesalGUIcons16x256x128")
self.NotesList.ButtonMoveDown.i:SetTexCoord(0.25,0.3125,0.5,0.625)
self.NotesList.UpdateAdditional = function(self,val)
self.ButtonMoveUp:Hide()
self.ButtonMoveDown:Hide()
for i=1,#self.List do
local line = self.List[i]
if line.index == 1 or line.index == 2 or line.index == #self.L or line.index == self.selected then
line.ignoreDrag = true
else
line.ignoreDrag = false
end
end
for i=1,#self.List-1 do
if self.selected == self.List[i].index then
self.ButtonMoveUp:SetPoint("BOTTOMRIGHT",self.List[i],"RIGHT",-2,0)
self.ButtonMoveDown:SetPoint("TOPRIGHT",self.List[i],"RIGHT",-2,0)
self.ButtonMoveUp:SetParent(self.List[i])
self.ButtonMoveDown:SetParent(self.List[i])
self.ButtonMoveUp.index = self.List[i].index - 2
self.ButtonMoveDown.index = self.List[i].index - 2
if i > 3 then
self.ButtonMoveUp:Show()
end
if i >= 3 and i <= #self.List-2 then
self.ButtonMoveDown:Show()
end
return
end
end
end
local function NotesListUpdateNames()
local bossesToGreen = {}
local mapID = C_Map.GetBestMapForUnit("player")
if mapID and module.db.mapToEncounter[mapID] then
local encounters = module.db.mapToEncounter[mapID]
if type(encounters) == 'table' then
for i=1,#encounters do
bossesToGreen[ encounters[i] ] = true
end
else
bossesToGreen[encounters] = true
end
end
self.NotesList.L = {}
self.NotesList.L[1] = "|cff55ee55"..L.messageTab1
self.NotesList.L[2] = L.NoteSelf
for i=1,#VMRT.Note.Black do
self.NotesList.L[i+2] = (VMRT.Note.AutoLoad[i] and (bossesToGreen[ VMRT.Note.AutoLoad[i] ] and "|cff00ff00" or "|cffffff00").."["..module.options:GetBossName(VMRT.Note.AutoLoad[i]).."]|r" or "")..(VMRT.Note.BlackNames[i] or i)
end
self.NotesList.L[#self.NotesList.L + 1] = "|cff00aaff"..L.NoteAdd
self.NotesList:Update()
end
NotesListUpdateNames()
self.NotesListUpdateNames = NotesListUpdateNames
local function UpdatePageAfterGettingNote()
if NoteIsSelfNow then
self.NotesList:SetListValue(2)
elseif BlackNoteNow then
self.NotesList:SetListValue(BlackNoteNow + 2)
else
self.NotesList:SetListValue(1)
end
end
self.UpdatePageAfterGettingNote = UpdatePageAfterGettingNote
module.options.LastIndex = 1
function self.NotesList:SetListValue(index)
module.options.LastIndex = index
module.options.buttonsend:SetShown(index == 1)
module.options.buttoncopy:SetShown(index > 2)
module.options.buttoncopyPersonal:SetShown(index > 2)
BlackNoteNow = nil
NoteIsSelfNow = nil
module.options.IsMainNoteNow = nil
if index == 1 then
module.options.DraftName:Enable()
module.options.RemoveDraft:Disable()
module.options.autoLoadDropdown:Enable()
elseif index > 2 then
module.options.DraftName:Enable()
module.options.RemoveDraft:Enable()
module.options.autoLoadDropdown:Enable()
else
module.options.DraftName:Disable()
module.options.RemoveDraft:Disable()
module.options.autoLoadDropdown:Disable()
end
if index == 1 then
module.options.NoteEditBox.EditBox:SetText(VMRT.Note.Text1 or "")
--module.options.DraftName:SetText( L.messageTab1 )
module.options.IsMainNoteNow = true
module.options.DraftName:SetText( VMRT.Note.DefName or "" )
module.options.autoLoadDropdown:SetText(VMRT.Note.AutoLoad[0] and module.options:GetBossName(VMRT.Note.AutoLoad[0]) or "-")
elseif index == 2 then
module.options.NoteEditBox.EditBox:SetText(VMRT.Note.SelfText or "")
module.options.DraftName:SetText( L.NoteSelf )
module.options.autoLoadDropdown:SetText("-")
NoteIsSelfNow = true
elseif index == #self.L then
VMRT.Note.Black[#VMRT.Note.Black + 1] = ""
tinsert(self.L,#self.L - 1,#VMRT.Note.Black)
module.options.NoteEditBox.EditBox:SetText("")
self:Update()
BlackNoteNow = #VMRT.Note.Black
module.options.DraftName:SetText( "" )
NotesListUpdateNames()
module.options.autoLoadDropdown:SetText("-")
else
index = index - 2
if IsShiftKeyDown() then
-- VMRT.Note.Black[index] = VMRT.Note.Text1
end
module.options.NoteEditBox.EditBox:SetText(VMRT.Note.Black[index] or "")
BlackNoteNow = index
module.options.DraftName:SetText( VMRT.Note.BlackNames[index] or "" )
module.options.autoLoadDropdown:SetText(VMRT.Note.AutoLoad[index] and module.options:GetBossName(VMRT.Note.AutoLoad[index]) or "-")
end
end
self.NotesList:SetScript("OnShow",function(self)
NotesListUpdateNames()
end)
function self.NotesList:HoverListValue(isHover,index)
if not isHover then
GameTooltip_Hide()
else
GameTooltip:SetOwner(self,"ANCHOR_CURSOR")
GameTooltip:AddLine(self.L[index])
if index == 2 then
GameTooltip:AddLine(L.NoteSelfTooltip)
elseif index ~= #self.L and index > 2 then
local i = index - 2
if VMRT.Note.BlackLastUpdateName[i] then
GameTooltip:AddLine(L.NoteLastUpdate..": "..VMRT.Note.BlackLastUpdateName[i].." ("..date("%d.%m.%Y %H:%M",VMRT.Note.BlackLastUpdateTime[i] or 0)..")")
end
--GameTooltip:AddLine(L.NoteTabCopyTooltip)
end
GameTooltip:Show()
end
end
function self.NotesList:OnDragFunction(obj1,obj2)
local index1,index2 = obj1.index,obj2.index
if index2 < 3 or index2 >= #self.L then
return
end
index1,index2 = index1 - 2,index2 - 2
local tmpBlack = VMRT.Note.Black[index1]
local tmpBlackNames = VMRT.Note.BlackNames[index1]
local tmpAutoLoad = VMRT.Note.AutoLoad[index1]
local tmpBlackLastUpdateName = VMRT.Note.BlackLastUpdateName[index1]
local tmpBlackLastUpdateTime = VMRT.Note.BlackLastUpdateTime[index1]
if index1 < index2 then
for i=index1,index2-1 do
VMRT.Note.Black[i] = VMRT.Note.Black[i + 1]
VMRT.Note.BlackNames[i] = VMRT.Note.BlackNames[i + 1]
VMRT.Note.AutoLoad[i] = VMRT.Note.AutoLoad[i + 1]
VMRT.Note.BlackLastUpdateName[i] = VMRT.Note.BlackLastUpdateName[i + 1]
VMRT.Note.BlackLastUpdateTime[i] = VMRT.Note.BlackLastUpdateTime[i + 1]
end
else
for i=index1,index2+1,-1 do
VMRT.Note.Black[i] = VMRT.Note.Black[i - 1]
VMRT.Note.BlackNames[i] = VMRT.Note.BlackNames[i - 1]
VMRT.Note.AutoLoad[i] = VMRT.Note.AutoLoad[i - 1]
VMRT.Note.BlackLastUpdateName[i] = VMRT.Note.BlackLastUpdateName[i - 1]
VMRT.Note.BlackLastUpdateTime[i] = VMRT.Note.BlackLastUpdateTime[i - 1]
end
end
VMRT.Note.Black[index2] = tmpBlack
VMRT.Note.BlackNames[index2] = tmpBlackNames
VMRT.Note.AutoLoad[index2] = tmpAutoLoad
VMRT.Note.BlackLastUpdateName[index2] = tmpBlackLastUpdateName
VMRT.Note.BlackLastUpdateTime[index2] = tmpBlackLastUpdateTime
NotesListUpdateNames()
end
self.DuplicateDraft = ELib:Button(self.tab.tabs[1],L.NoteDuplicate):Size(120,19):Point("RIGHT",0,0):Point("TOP",self.NotesList,0,1):OnClick(function (self)
local pos = #VMRT.Note.Black + 1
local text = module.options.LastIndex == 1 and (VMRT.Note.Text1 or "") or
module.options.LastIndex == 2 and (VMRT.Note.SelfText or "") or
(VMRT.Note.Black[module.options.LastIndex - 2] or "")
local title = (module.options.LastIndex > 2 and VMRT.Note.BlackNames[module.options.LastIndex - 2]) or
(module.options.LastIndex == 1 and VMRT.Note.DefName)
if not title then title = nil end
local boss = module.options.LastIndex == 1 and VMRT.Note.AutoLoad[0] or
module.options.LastIndex > 2 and VMRT.Note.AutoLoad[module.options.LastIndex - 2]
if not boss then boss = nil end
local lastUpdateName = module.options.LastIndex > 2 and VMRT.Note.BlackLastUpdateName[module.options.LastIndex - 2]
if not lastUpdateName then lastUpdateName = nil end
local lastUpdateTime = module.options.LastIndex > 2 and VMRT.Note.BlackLastUpdateTime[module.options.LastIndex - 2]
if not lastUpdateTime then lastUpdateTime = nil end
VMRT.Note.Black[pos] = text
VMRT.Note.BlackNames[pos] = title
VMRT.Note.AutoLoad[pos] = boss
VMRT.Note.BlackLastUpdateName[pos] = lastUpdateName
VMRT.Note.BlackLastUpdateTime[pos] = lastUpdateTime
NotesListUpdateNames()
module.options.NotesList:SetListValue(pos+2)
module.options.NotesList.selected = pos+2
module.options.NotesList:Update()
end)
self.DuplicateDraft:HideBorders()
self.RemoveDraft = ELib:Button(self.tab.tabs[1],L.NoteRemove):Size(120,19):Point("RIGHT",self.DuplicateDraft,"LEFT",-5,0):Point("TOP",self.NotesList,0,1):Disable():OnClick(function (self)
if not BlackNoteNow then
return
end
local size = #VMRT.Note.Black
for i=BlackNoteNow,size do
if i < size then
VMRT.Note.Black[i] = VMRT.Note.Black[i + 1]
VMRT.Note.BlackNames[i] = VMRT.Note.BlackNames[i + 1]
VMRT.Note.AutoLoad[i] = VMRT.Note.AutoLoad[i + 1]
VMRT.Note.BlackLastUpdateName[i] = VMRT.Note.BlackLastUpdateName[i + 1]
VMRT.Note.BlackLastUpdateTime[i] = VMRT.Note.BlackLastUpdateTime[i + 1]
else
VMRT.Note.Black[i] = nil
VMRT.Note.BlackNames[i] = nil
VMRT.Note.AutoLoad[i] = nil
VMRT.Note.BlackLastUpdateName[i] = nil
VMRT.Note.BlackLastUpdateTime[i] = nil
end
end
NotesListUpdateNames()
if BlackNoteNow == (#module.options.NotesList.L - 2) then
BlackNoteNow = BlackNoteNow - 1
end
module.options.NotesList:SetListValue(2+BlackNoteNow)
module.options.NotesList.selected = 2+(BlackNoteNow or 0) --blacknote_id can be nil if all blacks are removed
module.options.NotesList:Update()
end)
self.RemoveDraft:HideBorders()
self.DraftName = ELib:Edit(self.tab.tabs[1]):Size(0,18):Tooltip(L.NoteDraftName):Text(VMRT.Note.DefName or L.messageTab1):Point("TOPLEFT",self.NotesList,"TOPRIGHT",8,0):Point("RIGHT",self.RemoveDraft,"LEFT",-5,0):BackgroundText(L.NoteDraftName):OnChange(function(self,isUser)
self:BackgroundTextCheck()
if not isUser then return end
if BlackNoteNow then
VMRT.Note.BlackNames[ BlackNoteNow ] = self:GetText()
NotesListUpdateNames()
elseif not BlackNoteNow and not NoteIsSelfNow then
VMRT.Note.DefName = self:GetText()
end
end)
self.DraftName:SetBackdropColor(0, 0, 0, 0)
self.DraftName:SetBackdropBorderColor(0, 0, 0, 0)
self.DraftName:HideBorders()
ELib:DecorationLine(self.tab.tabs[1]):Point("TOP",0,-129-20):Point("LEFT",self.NotesList,"RIGHT",0,0):Point("RIGHT",'x',0,0):Size(0,1)
local function autoLoadDropdown_SetValue(self,encounterID)
local index = BlackNoteNow or 0
VMRT.Note.AutoLoad[index] = encounterID
module.options.autoLoadDropdown:SetText(encounterID and module.options:GetBossName(encounterID) or "-")
NotesListUpdateNames()
ELib:DropDownClose()
end
self.autoLoadDropdown = ELib:DropDown(self.tab.tabs[1],550,25):AddText(ENCOUNTER_JOURNAL_ENCOUNTER..":"):Point("TOPRIGHT",self.DuplicateDraft,"BOTTOMRIGHT",-2,-1):Size(550):SetText(VMRT.Note.AutoLoad[0] and L.bossName[ VMRT.Note.AutoLoad[0] ] or "-")
do
local List = self.autoLoadDropdown.List
List[#List+1] = {
text = NO,
func = autoLoadDropdown_SetValue,
}
for i=1,#module.db.encountersList do
local instance = module.db.encountersList[i]
List[#List+1] = {
text = type(instance[1])=='string' and instance[1] or (C_Map.GetMapInfo(instance[1] or 0) or {}).name or "???",
isTitle = true,
}
for j=2,#instance do
List[#List+1] = {
text = module.options:GetBossName(instance[j]),
arg1 = instance[j],
func = autoLoadDropdown_SetValue,
}
end
end
end
self.autoLoadDropdown:HideBorders()
self.autoLoadDropdown.Background:Hide()
self.autoLoadDropdown.Background:SetPoint("BOTTOMRIGHT",0,1)
self.autoLoadDropdown.Background:SetColorTexture(1,1,1,.3)
self.autoLoadDropdown.Text:SetJustifyH("LEFT")
self.autoLoadDropdown:SetScript("OnMouseDown",function(self)
self.Button:Click()
end)
self.autoLoadDropdown:SetScript("OnEnter",function(self)
self.Background:Show()
end)
self.autoLoadDropdown:SetScript("OnLeave",function(self)
self.Background:Hide()
end)
if MRT.isClassic then
self.autoLoadDropdown:Hide()
end
ELib:DecorationLine(self.tab.tabs[1]):Point("TOP",0,-129-40):Point("LEFT",self.NotesList,"RIGHT",0,0):Point("RIGHT",'x',0,0):Size(0,1)
local IsFormattingOn = VMRT.Note.OptionsFormatting
4 years ago
local IconsFormattingList = {}
self.optFormatting = ELib:Check(self.tab.tabs[1],FORMATTING,VMRT.Note.OptionsFormatting):Point("TOPLEFT",self.NotesList,"TOPRIGHT",15,-41):Size(15,15):OnClick(function(self)
if self:GetChecked() then
VMRT.Note.OptionsFormatting = true
else
VMRT.Note.OptionsFormatting = nil
end
IsFormattingOn = VMRT.Note.OptionsFormatting
module.options.NotesList:SetListValue(module.options.LastIndex or 1)
end)
--[[
self.textClear = ELib:Text(self.tab.tabs[1],"["..L.messagebutclear.."]"):Point("TOPLEFT",self.NotesList,"TOPRIGHT",120,-41-1):Color()
self.textClear:SetShadowColor(1,1,1,0)
self.textClear:SetShadowOffset(1,-1)
self.buttonClear = CreateFrame("Button",nil,self.NoteEditBox)
self.buttonClear:SetAllPoints(self.textClear)
self.buttonClear:SetScript("OnClick",function()
module.frame:Clear()
module.options.NoteEditBox.EditBox:SetText("")
end)
self.buttonClear:SetScript("OnEnter",function()
self.textClear:SetShadowColor(1,1,1,1)
end)
self.buttonClear:SetScript("OnLeave",function()
self.textClear:SetShadowColor(1,1,1,0)
end)
]]
ELib:DecorationLine(self.tab.tabs[1]):Point("TOP",0,-129-60):Point("LEFT",self.NotesList,"RIGHT",0,0):Point("RIGHT",'x',0,0):Size(0,1)
self.NoteEditBox = ELib:MultiEdit(self.tab.tabs[1]):Point("TOPLEFT",self.NotesList,"TOPRIGHT",2,-61):Size(616,395)
ELib:Border(self.NoteEditBox,0)
4 years ago
local function GSUB_Icon_Options(unformatted,spellID,iconSize)
local iconText
spellID = tonumber(spellID)
if not iconSize or iconSize == "" then
iconSize = 0
else
iconSize = min(tonumber(iconSize),40)
end
local preicon = predefSpellIcons[spellID]
if preicon then
iconText = "|T"..preicon..":"..iconSize.."|t"
else
local spellTexture = select(3,GetSpellInfo(spellID))
iconText = "|T"..(spellTexture or "Interface\\Icons\\INV_MISC_QUESTIONMARK")..":"..iconSize..":"..iconSize..":-6:0|t"
end
IconsFormattingList[iconText] = unformatted
return iconText
end
self.NoteEditBox.EditBox._SetText = self.NoteEditBox.EditBox.SetText
function self.NoteEditBox.EditBox:SetText(text)
if IsFormattingOn then
4 years ago
--wipe(IconsFormattingList)
text = text:gsub("||([cr])","|%1")
4 years ago
--:gsub("({spell:(%d+):?(%d*)})",GSUB_Icon_Options)
end
return self:_SetText(text)
end
function self.NoteEditBox.EditBox:OnTextChanged(isUser)
if not isUser and (not module.options.InsertFix or GetTime() - module.options.InsertFix > 0.1) then
return
end
local text = self:GetText()
if IsFormattingOn then
text = text:gsub("|([cr])","||%1")
4 years ago
--:gsub("|T.-|t",IconsFormattingList)
end
if NoteIsSelfNow then
VMRT.Note.SelfText = text
module.frame:UpdateText()
elseif BlackNoteNow then
VMRT.Note.Black[ BlackNoteNow ] = text
VMRT.Note.BlackLastUpdateName[BlackNoteNow] = MRT.SDB.charKey
VMRT.Note.BlackLastUpdateTime[BlackNoteNow] = time()
else
VMRT.Note.Text1 = text
if module.frame.text:GetText() ~= txtWithIcons(VMRT.Note.Text1) then
module.options.buttonsend:Anim(true)
else
module.options.buttonsend:Anim(false)
end
module.frame:UpdateText()
end
end
local last_highlight_start,last_highlight_end,last_cursor_pos = 0,0,0
local IsFormattingOn_Saved
self.NoteEditBox.EditBox:SetScript("OnKeyDown",function(self,key)
if IsFormattingOn and key == "LCTRL" then
module.options.InsertFix = nil
IsFormattingOn_Saved = true
IsFormattingOn = nil
local h_start,h_end = module.options.NoteEditBox:GetTextHighlight()
local h_cursor = self:GetCursorPosition()
local text = module.options.NoteEditBox.EditBox:GetText()
last_highlight_start,last_highlight_end,last_cursor_pos = h_start,h_end,h_cursor
local c_start,c_end,c_cursor = 0,0,0
text:sub(1,h_start):gsub("|([cr])",function() c_start = c_start + 1 end)
text:sub(1,h_end):gsub("|([cr])",function() c_end = c_end + 1 end)
text:sub(1,h_cursor):gsub("|([cr])",function() c_cursor = c_cursor + 1 end)
text = text:gsub("|([cr])","||%1")
module.options.NoteEditBox.EditBox:_SetText(text)
module.options.NoteEditBox.EditBox:HighlightText( h_start+c_start, h_end+c_end )
module.options.NoteEditBox.EditBox:SetCursorPosition( h_cursor+c_cursor )
end
end)
self.NoteEditBox.EditBox:SetScript("OnKeyUp",function(self,key)
if IsFormattingOn_Saved and key == "LCTRL" then
local text = module.options.NoteEditBox.EditBox:GetText()
local h_start,h_end = module.options.NoteEditBox:GetTextHighlight()
local h_cursor = self:GetCursorPosition()
local c_start,c_end,c_cursor = 0,0,0
text:sub(1,h_start):gsub("||([cr])",function() c_start = c_start + 1 end)
text:sub(1,h_end):gsub("||([cr])",function() c_end = c_end + 1 end)
text:sub(1,h_cursor):gsub("||([cr])",function() c_cursor = c_cursor + 1 end)
IsFormattingOn = true
IsFormattingOn_Saved = nil
module.options.InsertFix = nil
module.options.NotesList:SetListValue(module.options.LastIndex or 1)
module.options.NoteEditBox.EditBox:HighlightText( h_start-c_start,h_end-c_end )
module.options.NoteEditBox.EditBox:SetCursorPosition( h_cursor-c_cursor )
end
end)
self.buttonsend = ELib:Button(self.tab.tabs[1],L.messagebutsend):Size(0,30):Point("LEFT",self.NotesList,"TOPRIGHT",4,0):Point("BOTTOM",self,"BOTTOM",0,2):Point("RIGHT",self,"RIGHT",-2,0):Tooltip(L.messagebutsendtooltip):OnClick(function (self)
module.frame:Save()
if IsShiftKeyDown() then
local text = VMRT.Note.Text1 or ""
text = text:gsub("||c........","")
text = text:gsub("||r","")
text = text:gsub("||T.-:0||t ","")
for i=1,8 do
text = text:gsub(module.db.iconsLocalizatedNames[i],"{rt"..i.."}")
for _,lang in pairs(iconsLangs) do
text = text:gsub(module.db["icons"..lang.."Names"][i],"{rt"..i.."}")
end
end
text = text:gsub("%b{}",function(p)
if p and p:match("^{rt%d}$") then
return p
else
return ""
end
end)
4 years ago
if MRT.isBC and MRT.locale == "ruRU" then --fix bug for icons on ru client
text = text:gsub("%b{}",function(p)
if p and p:match("^{rt%d}$") then
return module.db.iconsLocalizatedNames[tonumber(p:match("%d+") or "") or 0]
end
end)
end
local lines = {strsplit("\n", text)}
for i=1,#lines do
if lines[i] ~= "" then
SendChatMessage(lines[i],(IsInGroup(LE_PARTY_CATEGORY_INSTANCE) and "INSTANCE_CHAT") or (IsInRaid() and "RAID") or "PARTY")
end
end
end
module.options.buttonsend:Anim(false)
end)
function self.buttonsend:Anim(on)
if on then
self.t = self.t or 0
self:SetScript("OnUpdate",function(self,elapsed)
self.t = (self.t + elapsed) % 4
local c = 0.05 * (self.t > 2 and (4-self.t) or self.t)
if MRT.is10 or MRT.isLK1 then
3 years ago
self.Texture:SetGradient("VERTICAL",CreateColor(0.0+c,0.06+c,0.0+c,1), CreateColor(0.05+c,0.21+c,0.05+c,1))
else
self.Texture:SetGradientAlpha("VERTICAL",0.0+c,0.06+c,0.0+c,1, 0.05+c,0.21+c,0.05+c,1)
end
end)
else
self:SetScript("OnUpdate",nil)
if MRT.is10 or MRT.isLK1 then
3 years ago
self.Texture:SetGradient("VERTICAL",CreateColor(0.05,0.06,0.09,1), CreateColor(0.20,0.21,0.25,1))
else
self.Texture:SetGradientAlpha("VERTICAL",0.05,0.06,0.09,1, 0.20,0.21,0.25,1)
end
end
end
self.buttoncopyPersonal = ELib:Button(self.tab.tabs[1],L.NoteMoveToPersonal):Size(180,30):Point("BOTTOM",self,"BOTTOM",0,2):Point("RIGHT",self,"RIGHT",-2,0):OnClick(function (self)
if not BlackNoteNow then
return
end
VMRT.Note.SelfText = VMRT.Note.Black[BlackNoteNow]
module.options.NotesList:SetListValue(2)
module.options.NotesList.selected = 2
module.options.NotesList:Update()
module.frame:UpdateText()
end)
self.buttoncopyPersonal:Hide()
self.buttoncopy = ELib:Button(self.tab.tabs[1],L.messageButCopy):Size(0,30):Point("LEFT",self.NotesList,"TOPRIGHT",4,0):Point("BOTTOM",self,"BOTTOM",0,2):Point("RIGHT",self.buttoncopyPersonal,"LEFT",-5,0):OnClick(function (self)
if not BlackNoteNow then
return
end
module.frame:Save(BlackNoteNow)
module.options.NotesList:SetListValue(1)
module.options.NotesList.selected = 1
module.options.NotesList:Update()
end)
self.buttoncopy:Hide()
local function AddTextToEditBox(self,text,mypos,noremove)
local addedText = nil
if not self then
addedText = text
else
addedText = self.iconText
if IsShiftKeyDown() then
addedText = self.iconTextShift
end
end
if not noremove then
module.options.NoteEditBox.EditBox:Insert("")
end
local txt = module.options.NoteEditBox.EditBox:GetText()
local pos = module.options.NoteEditBox.EditBox:GetCursorPosition()
if not self and type(mypos)=='number' then
pos = mypos
end
txt = string.sub (txt, 1 , pos) .. addedText .. string.sub (txt, pos+1)
module.options.InsertFix = GetTime()
module.options.NoteEditBox.EditBox:SetText(txt)
local adjust = 0
if IsFormattingOn then
addedText:gsub("||",function() adjust = adjust + 1 end)
end
module.options.NoteEditBox.EditBox:SetCursorPosition(pos+addedText:len()-adjust)
end
self.buttonicons = {}
for i=1,8 do
local button = CreateFrame("Button", nil,self.tab.tabs[1])
self.buttonicons[i] = button
button:SetSize(18,18)
button:SetPoint("TOPLEFT", 10+(i-1)*20,-30)
button.back = button:CreateTexture(nil, "BACKGROUND")
button.back:SetTexture("Interface\\TargetingFrame\\UI-RaidTargetingIcon_"..i)
button.back:SetAllPoints()
button:RegisterForClicks("LeftButtonDown")
button.iconText = module.db.iconsLocalizatedNames[i]
button:SetScript("OnClick", AddTextToEditBox)
end
for i=1,(MRT.is10 and 13 or 12) do
local button = CreateFrame("Button", nil,self.tab.tabs[1])
self.buttonicons[i] = button
button:SetSize(18,18)
button:SetPoint("TOPLEFT", 170+(i-1)*20,-30)
button.back = button:CreateTexture(nil, "BACKGROUND")
local iconData = module.db.otherIconsList[i]
button.back:SetTexture(iconData[2])
if iconData[3] then
button.back:SetTexCoord(unpack(iconData,3,6))
end
button.back:SetAllPoints()
button:RegisterForClicks("LeftButtonDown")
button.iconText = iconData[1]
button:SetScript("OnClick", AddTextToEditBox)
end
self.OtherIconsButton = ELib:Button(self.tab.tabs[1],L.NoteOtherIcons):Size(120,20):Point("TOPLEFT",self.buttonicons[#self.buttonicons],"TOPRIGHT",5,1):OnClick(function()
module.options.OtherIconsFrame:ShowClick("TOPRIGHT")
end)
self.OtherIconsFrame = ELib:Popup(L.NoteOtherIcons):Size(300,300)
self.OtherIconsFrame.ScrollFrame = ELib:ScrollFrame(self.OtherIconsFrame):Size(self.OtherIconsFrame:GetWidth()-10,self.OtherIconsFrame:GetHeight()-25):Point("TOP",0,-20):Height(500)
local function CreateOtherIcon(pointX,pointY,texture,iconText)
local self = CreateFrame("Button", nil,self.OtherIconsFrame.ScrollFrame.C)
self:SetSize(18,18)
self:SetPoint("TOPLEFT",pointX,pointY)
self.texture = self:CreateTexture(nil, "BACKGROUND")
self.texture:SetTexture(texture)
self.texture:SetAllPoints()
self:RegisterForClicks("LeftButtonDown")
self.iconText = iconText
self:SetScript("OnClick", AddTextToEditBox)
return self
end
self.OtherIconsFrame.CreateOtherIcon = CreateOtherIcon
self.OtherIconsFrame.OnShow = function(self)
self.OnShow = nil
local GetSpellInfo = GetSpellInfo
local line = 1
local inLine = 0
for i=(MRT.is10 and 14 or 13),#module.db.otherIconsList-3 do
local iconData = module.db.otherIconsList[i]
local icon = CreateOtherIcon(5+inLine*20,-2-(line-1)*20,iconData[2],iconData[1])
if iconData[3] then
icon.texture:SetTexCoord( unpack(iconData,3,6) )
end
inLine = inLine + 1
if inLine > 12 then
line = line + 1
inLine = 0
end
end
if inLine > 0 then
line = line + 1
end
inLine = 0
for i=1,#module.db.otherIconsAdditionalList do
local spellID = module.db.otherIconsAdditionalList[i]
if spellID == 0 then
line = line + 1
inLine = 0
elseif type(spellID) == 'string' then
CreateOtherIcon(5+inLine*20,-2-(line-1)*20,spellID,"||T"..spellID..":0||t")
inLine = inLine + 1
if inLine > 12 and (not module.db.otherIconsAdditionalList[i+1] or module.db.otherIconsAdditionalList[i+1]~=0) then
line = line + 1
inLine = 0
end
else
local _,_,spellTexture = GetSpellInfo( spellID )
if predefSpellIcons[spellID] then
spellTexture = predefSpellIcons[spellID]
end
CreateOtherIcon(5+inLine*20,-2-(line-1)*20,spellTexture,"{spell:"..spellID.."}")
inLine = inLine + 1
if inLine > 12 and (not module.db.otherIconsAdditionalList[i+1] or module.db.otherIconsAdditionalList[i+1]~=0) then
line = line + 1
inLine = 0
end
end
end
module.options.OtherIconsFrame.ScrollFrame:SetNewHeight( max(module.options.OtherIconsFrame:GetHeight()-40 , line * 20 + 4) )
end
self:SetScript("OnHide",function (self)
self.OtherIconsFrame:Hide()
end)
self.dropDownColor = ELib:DropDown(self.tab.tabs[1],170,10):Point(558,-30):Size(100):SetText(L.NoteColor)
self.dropDownColor.list = {
{L.NoteColorRed,"|cffff0000"},
{L.NoteColorGreen,"|cff00ff00"},
{L.NoteColorBlue,"|cff0000ff"},
{L.NoteColorYellow,"|cffffff00"},
{L.NoteColorPurple,"|cffff00ff"},
{L.NoteColorAzure,"|cff00ffff"},
{L.NoteColorBlack,"|cff000000"},
{L.NoteColorGrey,"|cff808080"},
{L.NoteColorRedSoft,"|cffee5555"},
{L.NoteColorGreenSoft,"|cff55ee55"},
{L.NoteColorBlueSoft,"|cff5555ee"},
}
local classNames = MRT.GDB.ClassList
for i,class in ipairs(classNames) do
local colorTable = RAID_CLASS_COLORS[class]
if colorTable and type(colorTable)=="table" then
self.dropDownColor.list[#self.dropDownColor.list + 1] = {L.classLocalizate[class] or class,"|c"..(colorTable.colorStr or "ffaaaaaa")}
end
end
self.dropDownColor:SetScript("OnEnter",function (self)
ELib.Tooltip.Show(self,"ANCHOR_LEFT",L.NoteColor,{L.NoteColorTooltip1,1,1,1,true},{L.NoteColorTooltip2,1,1,1,true})
end)
self.dropDownColor:SetScript("OnLeave",function ()
ELib.Tooltip:Hide()
end)
function self.dropDownColor:SetValue(colorCode)
ELib:DropDownClose()
local selectedStart,selectedEnd = module.options.NoteEditBox.EditBox:GetTextHighlight()
colorCode = string.gsub(colorCode,"|","||")
if selectedStart == selectedEnd then
AddTextToEditBox(nil,colorCode.."||r",nil,true)
else
AddTextToEditBox(nil,"||r",selectedEnd,true)
AddTextToEditBox(nil,colorCode,selectedStart,true)
end
end
for i=1,#self.dropDownColor.list do
local colorData = self.dropDownColor.list[i]
self.dropDownColor.List[i] = {
text = colorData[2]..colorData[1],
func = self.dropDownColor.SetValue,
justifyH = "CENTER",
arg1 = colorData[2],
}
end
self.dropDownColor.Lines = #self.dropDownColor.List
local function RaidNamesOnEnter(self)
self.html:SetShadowColor(0.2, 0.2, 0.2, 1)
end
local function RaidNamesOnLeave(self)
self.html:SetShadowColor(0, 0, 0, 1)
end
self.raidnames = {}
for i=1,40 do
local button = CreateFrame("Button", nil,self.tab.tabs[1])
self.raidnames[i] = button
button:SetSize(93,14)
button:SetPoint("TOPLEFT", 15+math.floor((i-1)/5)*95,-55-14*((i-1)%5))
button.html = ELib:Text(button,"",11):Color()
button.html:SetAllPoints()
button.txt = ""
button:RegisterForClicks("LeftButtonDown")
button.iconText = ""
button:SetScript("OnClick", AddTextToEditBox)
button:SetScript("OnEnter", RaidNamesOnEnter)
button:SetScript("OnLeave", RaidNamesOnLeave)
end
self.lastUpdate = ELib:Text(self.tab.tabs[1],"",11):Size(600,20):Point("TOPLEFT",self.NotesList,"BOTTOMLEFT",3,-6):Top():Color()
if VMRT.Note.LastUpdateName and VMRT.Note.LastUpdateTime then
self.lastUpdate:SetText( L.NoteLastUpdate..": "..VMRT.Note.LastUpdateName.." ("..date("%H:%M:%S %d.%m.%Y",VMRT.Note.LastUpdateTime)..")" )
end
self.lastUpdate:Hide()
self.chkEnable = ELib:Check(self,L.Enable,VMRT.Note.enabled):Point(720,-17):Tooltip("/rt note|n/rt n"):Size(18,18):AddColorState():OnClick(function(self)
if self:GetChecked() then
module:Enable()
else
module:Disable()
end
end)
self.chkFix = ELib:Check(self,L.messagebutfix,VMRT.Note.Fix):Point(590,-17):Tooltip(L.messagebutfixtooltip):Size(18,18):OnClick(function(self)
if self:GetChecked() then
VMRT.Note.Fix = true
module.frame:SetMovable(false)
module.frame:EnableMouse(false)
module.frame.buttonResize:Hide()
MRT.lib.AddShadowComment(module.frame,1)
else
VMRT.Note.Fix = nil
module.frame:SetMovable(true)
module.frame:EnableMouse(true)
module.frame.buttonResize:Show()
MRT.lib.AddShadowComment(module.frame,nil,L.message)
end
end)
self.chkOnlyPromoted = ELib:Check(self.tab.tabs[2],L.NoteOnlyPromoted,VMRT.Note.OnlyPromoted):Point(15,-15):Tooltip(L.NoteOnlyPromotedTooltip):OnClick(function(self)
if self:GetChecked() then
VMRT.Note.OnlyPromoted = true
else
VMRT.Note.OnlyPromoted = nil
end
end)
self.chkOnlyInRaid = ELib:Check(self.tab.tabs[2],L.MarksBarDisableInRaid,VMRT.Note.HideOutsideRaid):Point(15,-40):OnClick(function(self)
if self:GetChecked() then
VMRT.Note.HideOutsideRaid = true
else
VMRT.Note.HideOutsideRaid = nil
end
module:Visibility()
end)
self.chkOnlyInRaidKInstance = ELib:Check(self.tab.tabs[2],L.NoteShowOnlyInRaid,VMRT.Note.ShowOnlyInRaid):Point(15,-65):OnClick(function(self)
if self:GetChecked() then
VMRT.Note.ShowOnlyInRaid = true
module:RegisterEvents('ZONE_CHANGED_NEW_AREA')
else
VMRT.Note.ShowOnlyInRaid = nil
module:UnregisterEvents('ZONE_CHANGED_NEW_AREA')
end
module:Visibility()
end)
self.chkOnlySelf = ELib:Check(self.tab.tabs[2],L.NoteShowOnlyPersonal,VMRT.Note.ShowOnlyPersonal):Point(15,-90):OnClick(function(self)
if self:GetChecked() then
VMRT.Note.ShowOnlyPersonal = true
else
VMRT.Note.ShowOnlyPersonal = nil
end
module.frame:UpdateText()
end)
self.chkHideInCombat = ELib:Check(self.tab.tabs[2],L.NoteHideInCombat,VMRT.Note.HideInCombat):Point(15,-115):OnClick(function(self)
if self:GetChecked() then
VMRT.Note.HideInCombat = true
module:RegisterEvents('PLAYER_REGEN_DISABLED','PLAYER_REGEN_ENABLED')
else
VMRT.Note.HideInCombat = nil
module:UnregisterEvents('PLAYER_REGEN_DISABLED','PLAYER_REGEN_ENABLED')
end
module:Visibility()
end)
self.chkSaveAllNew = ELib:Check(self.tab.tabs[2],L.NoteSaveAllNew,VMRT.Note.SaveAllNew):Point(15,-140):OnClick(function(self)
if self:GetChecked() then
VMRT.Note.SaveAllNew = true
else
VMRT.Note.SaveAllNew = nil
end
end)
self.chkEnableWhenReceive = ELib:Check(self.tab.tabs[2],L.NoteEnableWhenReceive,VMRT.Note.EnableWhenReceive):Point(15,-165):OnClick(function(self)
if self:GetChecked() then
VMRT.Note.EnableWhenReceive = true
else
VMRT.Note.EnableWhenReceive = nil
end
end)
self.sliderFontSize = ELib:Slider(self.tab.tabs[2],L.NoteFontSize):Size(300):Point(16,-200):Range(6,72):SetTo(VMRT.Note.FontSize or 12):OnChange(function(self,event)
event = event - event%1
VMRT.Note.FontSize = event
module.frame:UpdateFont()
self.tooltipText = event
self:tooltipReload(self)
end)
local function DropDownFont_Click(_,arg)
VMRT.Note.FontName = arg
local FontNameForDropDown = arg:match("\\([^\\]*)$")
module.options.dropDownFont:SetText(FontNameForDropDown or arg)
ELib:DropDownClose()
module.frame:UpdateFont()
end
self.dropDownFont = ELib:DropDown(self.tab.tabs[2],350,10):Point(15,-230):Size(300)
for i=1,#MRT.F.fontList do
self.dropDownFont.List[i] = {}
local info = self.dropDownFont.List[i]
info.text = MRT.F.fontList[i]
info.arg1 = MRT.F.fontList[i]
info.func = DropDownFont_Click
info.font = MRT.F.fontList[i]
info.justifyH = "CENTER"
end
for name,font in MRT.F.IterateMediaData("font") do
local info = {}
self.dropDownFont.List[#self.dropDownFont.List+1] = info
info.text = name
info.arg1 = font
info.func = DropDownFont_Click
info.font = font
info.justifyH = "CENTER"
end
do
local arg = VMRT.Note.FontName or MRT.F.defFont
local FontNameForDropDown = arg:match("\\([^\\]*)$")
self.dropDownFont:SetText(FontNameForDropDown or arg)
end
self.chkOutline = ELib:Check(self.tab.tabs[2],L.messageOutline,VMRT.Note.Outline):Point("LEFT",self.dropDownFont,"RIGHT",15,0):OnClick(function(self)
if self:GetChecked() then
VMRT.Note.Outline = true
else
VMRT.Note.Outline = nil
end
module.frame:UpdateFont()
end)
self.slideralpha = ELib:Slider(self.tab.tabs[2],L.messagebutalpha):Size(300):Point(16,-275):Range(0,100):SetTo(VMRT.Note.Alpha or 100):OnChange(function(self,event)
event = event - event%1
VMRT.Note.Alpha = event
module.frame:SetAlpha(event/100)
self.tooltipText = event
self:tooltipReload(self)
end)
self.sliderscale = ELib:Slider(self.tab.tabs[2],L.messagebutscale):Size(300):Point(16,-345):Range(5,200):SetTo(VMRT.Note.Scale or 100):OnChange(function(self,event)
event = event - event%1
VMRT.Note.Scale = event
MRT.F.SetScaleFix(module.frame,event/100)
self.tooltipText = event
self:tooltipReload(self)
end)
self.slideralphaback = ELib:Slider(self.tab.tabs[2],L.messageBackAlpha):Size(300):Point(16,-310):Range(0,100):SetTo(VMRT.Note.ScaleBack or 100):OnChange(function(self,event)
event = event - event%1
VMRT.Note.ScaleBack = event
module.frame.background:SetColorTexture(0, 0, 0, event/100)
self.tooltipText = event
self:tooltipReload(self)
end)
self.moreOptionsDropDown = ELib:DropDown(self.tab.tabs[2],275,#frameStrataList+1):Point(15,-380):Size(300):SetText(L.NoteFrameStrata)
local function moreOptionsDropDown_SetVaule(_,arg)
VMRT.Note.Strata = arg
ELib:DropDownClose()
for i=1,#self.moreOptionsDropDown.List-1 do
self.moreOptionsDropDown.List[i].checkState = VMRT.Note.Strata == self.moreOptionsDropDown.List[i].arg1
end
module.frame:SetFrameStrata(arg)
end
for i=1,#frameStrataList do
self.moreOptionsDropDown.List[i] = {
text = frameStrataList[i],
checkState = VMRT.Note.Strata == frameStrataList[i],
radio = true,
arg1 = frameStrataList[i],
func = moreOptionsDropDown_SetVaule,
}
end
tinsert(self.moreOptionsDropDown.List,{text = L.minimapmenuclose, func = function()
ELib:DropDownClose()
end})
self.ButtonToCenter = ELib:Button(self.tab.tabs[2],L.MarksBarResetPos):Size(300,20):Point(15,-410):Tooltip(L.MarksBarResetPosTooltip):OnClick(function()
VMRT.Note.Left = nil
VMRT.Note.Top = nil
module.frame:ClearAllPoints()
module.frame:SetPoint("CENTER",UIParent, "CENTER", 0, 0)
end)
ELib:DecorationLine(self.tab.tabs[2]):Point("LEFT",0,0):Point("RIGHT",0,0):Size(0,1):Point("TOP",self.ButtonToCenter,"BOTTOM",0,-5)
ELib:Text(self.tab.tabs[2],L.NoteTimers,14):Point("TOP",self.ButtonToCenter,"BOTTOM",0,-9):Point("LEFT",20,0):Color()
self.chkTimersHidePassed = ELib:Check(self.tab.tabs[2],L.NoteTimersHidePassed,VMRT.Note.TimerPassedHide):Point("TOPLEFT",self.ButtonToCenter,"BOTTOMLEFT",0,-25):OnClick(function(self)
if self:GetChecked() then
VMRT.Note.TimerPassedHide = true
else
VMRT.Note.TimerPassedHide = nil
end
end)
self.chkTimersGlow = ELib:Check(self.tab.tabs[2],L.NoteTimersGlow,VMRT.Note.TimerGlow):Point("TOPLEFT",self.chkTimersHidePassed,"BOTTOMLEFT",0,-5):OnClick(function(self)
if self:GetChecked() then
VMRT.Note.TimerGlow = true
else
VMRT.Note.TimerGlow = nil
end
end)
4 years ago
self.chkTimersOnlyMy = ELib:Check(self.tab.tabs[2],L.NoteTimersOnlyMy,VMRT.Note.TimerOnlyMy):Point("TOPLEFT",self.chkTimersGlow,"BOTTOMLEFT",0,-5):OnClick(function(self)
if self:GetChecked() then
VMRT.Note.TimerOnlyMy = true
else
VMRT.Note.TimerOnlyMy = nil
end
module.frame:UpdateText()
end)
4 years ago
local testGlowDelay
local function TestGlow()
module.frame:HideGlow()
module.frame:ShowGlow()
if testGlowDelay then
testGlowDelay:Cancel()
end
testGlowDelay = C_Timer.NewTimer(3,function()
module.frame:HideGlow()
end)
end
self.frameTypeGlow1 = ELib:Radio(self.tab.tabs[2],""):Point("LEFT",self.chkTimersGlow,425,0):OnClick(function()
self.frameTypeGlow1:SetChecked(true)
self.frameTypeGlow2:SetChecked(false)
self.frameTypeGlow3:SetChecked(false)
VMRT.Note.TimerGlowType = 1
TestGlow()
end)
self.frameTypeGlow1.f = CreateFrame("Frame",nil,self.frameTypeGlow1)
self.frameTypeGlow1.f:SetPoint("LEFT",self.frameTypeGlow1,"RIGHT",5,0)
self.frameTypeGlow1.f:SetSize(40,15)
self.frameTypeGlow2 = ELib:Radio(self.tab.tabs[2],""):Point("LEFT",self.frameTypeGlow1,100,0):OnClick(function()
self.frameTypeGlow1:SetChecked(false)
self.frameTypeGlow2:SetChecked(true)
self.frameTypeGlow3:SetChecked(false)
VMRT.Note.TimerGlowType = 2
TestGlow()
end)
self.frameTypeGlow2.f = CreateFrame("Frame",nil,self.frameTypeGlow2)
self.frameTypeGlow2.f:SetPoint("LEFT",self.frameTypeGlow2,"RIGHT",5,0)
self.frameTypeGlow2.f:SetSize(40,15)
self.frameTypeGlow3 = ELib:Radio(self.tab.tabs[2],""):Point("LEFT",self.frameTypeGlow2,100,0):OnClick(function()
self.frameTypeGlow1:SetChecked(false)
self.frameTypeGlow2:SetChecked(false)
self.frameTypeGlow3:SetChecked(true)
VMRT.Note.TimerGlowType = 3
TestGlow()
end)
self.frameTypeGlow3.f = CreateFrame("Frame",nil,self.frameTypeGlow3)
self.frameTypeGlow3.f:SetPoint("LEFT",self.frameTypeGlow3,"RIGHT",5,0)
self.frameTypeGlow3.f:SetSize(40,15)
local LCG = LibStub("LibCustomGlow-1.0",true)
if LCG then
LCG.PixelGlow_Start(self.frameTypeGlow1.f,nil,nil,nil,nil,2,1,1)
LCG.AutoCastGlow_Start(self.frameTypeGlow3.f)
LCG.ButtonGlow_Start(self.frameTypeGlow2.f)
end
if VMRT.Note.TimerGlowType == 2 then
self.frameTypeGlow2:SetChecked(true)
elseif VMRT.Note.TimerGlowType == 3 then
self.frameTypeGlow3:SetChecked(true)
else
self.frameTypeGlow1:SetChecked(true)
end
if VMRT.Note.Text1 then
self.NoteEditBox.EditBox:SetText(VMRT.Note.Text1)
end
self.textHelp = ELib:Text(self.tab.tabs[3],
"|cffffff00||cffRRGGBB|r...|cffffff00||r|r - "..L.NoteHelp1..
(not MRT.isClassic and "|n|cffffff00{D}|r...|cffffff00{/D}|r - "..format(L.NoteHelp2,DAMAGER) or "")..
(not MRT.isClassic and "|n|cffffff00{H}|r...|cffffff00{/H}|r - "..format(L.NoteHelp2,HEALER) or "")..
(not MRT.isClassic and "|n|cffffff00{T}|r...|cffffff00{/T}|r - "..format(L.NoteHelp2,TANK) or "")..
"|n|cffffff00{spell:|r|cff00ff0017|r|cffffff00}|r - "..L.NoteHelp3..
"|n|cffffff00{self}|r - "..L.NoteHelp4..
"|n|cffffff00{p:|r|cff00ff00JaneD|r|cffffff00,|r|cff00ff00JennyB-HowlingFjord|r|cffffff00}|r...|cffffff00{/p}|r - "..L.NoteHelp5..
"|n|cffffff00{!p:|r|cff00ff00Leeroy|r|cffffff00,|r|cff00ff00Juron|r|cffffff00}|r...|cffffff00{/p}|r - "..L.NoteHelp5b..
"|n|cffffff00{icon:|r|cff00ff00Interface/Icons/inv_hammer_unique_sulfuras|r|cffffff00}|r - "..L.NoteHelp6..
"|n|cffffff00{c:|r|cff00ff00Paladin,Priest|r|cffffff00}|r...|cffffff00{/c}|r - "..L.NoteHelp8..
"|n|cffffff00{!c:|r|cff00ff00Mage,Hunter|r|cffffff00}|r...|cffffff00{/c}|r - "..L.NoteHelp8b..
"|n|cffffff00{g|r|cff00ff002|r|cffffff00}|r...|cffffff00{/g}|r - "..L.NoteHelp10..
"|n|cffffff00{!g|r|cff00ff0034|r|cffffff00}|r...|cffffff00{/g}|r - "..L.NoteHelp10b..
(MRT.isClassic and "|n|cffffff00{race:|r|cff00ff00troll,orc|r|cffffff00}|r...|cffffff00{/race}|r - "..L.NoteHelp11 or "")..
(MRT.isClassic and "|n|cffffff00{!race:|r|cff00ff00dwarf|r|cffffff00}|r...|cffffff00{/race}|r - "..L.NoteHelp11b or "")..
("|n|cffffff00{time:|r|cff00ff002:45|r|cffffff00}|r - "..L.NoteHelp7 or "")..
(not MRT.isClassic and "|n|cffffff00{p|r|cff00ff002|r|cffffff00}|r...|cffffff00{/p}|r - "..L.NoteHelp9 or "")
):Point("TOPLEFT",10,-20):Point("TOPRIGHT",-10,-20):Color()
self.advancedHelp = ELib:Button(self.tab.tabs[3],L.NoteHelpAdvanced):Size(400,20):Point("TOP",self.textHelp,"BOTTOM",0,-20):OnClick(function()
--module.options.textHelpAdv:SetShown(not module.options.textHelpAdv:IsShown())
module.options.advancedScroll:SetShown(not module.options.advancedScroll:IsShown())
end)
self.advancedScroll = ELib:ScrollFrame(self.tab.tabs[3]):Size(850,100):Point("TOP",self.advancedHelp,"BOTTOM",0,-20):Point("BOTTOM",self.tab.tabs[3],"BOTTOM",0,0):Height(400):Shown(false)
self.advancedScroll.C:SetWidth(850 - 16)
ELib:Border(self.advancedScroll,0)
ELib:DecorationLine(self.advancedScroll):Point("TOPLEFT",0,1):Point("BOTTOMRIGHT",'x',"TOPRIGHT",0,0)
self.textHelpAdv = ELib:Text(self.advancedScroll.C,
"|cffffff00{time:|r|cff00ff001:06,p2|r|cffffff00}|r - "..L.NoteHelpAdv1..
"|n|cffffff00{time:|r|cff00ff000:30,SCC:17:2|r|cffffff00}|r - "..L.NoteHelpAdv2..
"|n|cffffff00{time:|r|cff00ff002:00,e,customevent|r|cffffff00}|r - "..L.NoteHelpAdv3..
"|n|cffffff00{time:|r|cff00ff003:40,glowall|r|cffffff00}|r - "..L.NoteHelpAdv6..
"|n|cffffff00{time:|r|cff00ff004:15,glow|r|cffffff00}|r - "..L.NoteHelpAdv7..
"|n|cffffff00{time:|r|cff00ff000:45,wa:nzoth_hs1|r|cffffff00}|r - "..L.NoteHelpAdv4..
"|n WA Function example:|n Events: |cffffff00MRT_NOTE_TIME_EVENT|r|n |cffff8bf3function(event,...)|n if event == \"MRT_NOTE_TIME_EVENT\" then|n local timerName, timeLeft, noteText = ...|n if timerName == \"nzoth_hs1\" and timeLeft == 3 then|n return true|n end|n end|n end|r|n"..
"|n"..L.NoteHelpAdv5.."|n |cffe6ff15{time:0:30,SCC:17:2,wa:eventName1,wa:eventName2}|r|n |cffff9f05{time:1:40,p:Shade of Kael'thas}|r|n |cffe6ff15{p,SCC:17:2}Until end of the fight{/p}|r|n |cffff9f05{p,SCC:17:2,SCC:17:3}Until second condition{/p}|r|n |cffe6ff15{pShade of Kael'thas}Phase with name{/p}|r|n |cffff9f05{time:0:20,p2,wa:use_hs,glowall}|r"
):Point("LEFT",10,0):Point("RIGHT",-10,0):Point("TOP",0,-5):Color()
local height = self.textHelpAdv:GetHeight()
if height and height > 100 then
self.advancedScroll:Height(height + 10)
end
module:RegisterEvents("GROUP_ROSTER_UPDATE")
function self:OnShow()
module.main:GROUP_ROSTER_UPDATE()
end
self.isWide = true
end
module.frame = CreateFrame("Frame","MRTNote",UIParent)
module.frame:SetSize(200,100)
module.frame:SetPoint("CENTER",UIParent, "CENTER", 0, 0)
module.frame:EnableMouse(true)
module.frame:SetMovable(true)
module.frame:RegisterForDrag("LeftButton")
module.frame:SetScript("OnDragStart", function(self)
if self:IsMovable() then
self:StartMoving()
end
end)
module.frame:SetScript("OnDragStop", function(self)
self:StopMovingOrSizing()
VMRT.Note.Left = self:GetLeft()
VMRT.Note.Top = self:GetTop()
end)
module.frame:SetFrameStrata("HIGH")
module.frame:SetResizable(true)
if MRT.is10 or MRT.isLK1 then
3 years ago
module.frame:SetResizeBounds(30, 30, 2000, 2000)
else
module.frame:SetMinResize(30, 30)
end
module.frame:SetScript("OnSizeChanged", function (self, width, height)
local width_, height_ = self:GetSize()
if VMRT and VMRT.Note then
VMRT.Note.Width = width
VMRT.Note.Height = height
module.frame:UpdateText()
end
module.frame.sf.C:SetWidth( width_ )
end)
module.frame:Hide()
module.frame.sf = CreateFrame("ScrollFrame", nil, module.frame)
module.frame.sf:SetPoint("TOPLEFT",0,0)
module.frame.sf:SetAllPoints()
module.frame.sf.C = CreateFrame("Frame", nil, module.frame.sf)
module.frame.sf:SetScrollChild(module.frame.sf.C)
module.frame.sf.C:SetSize(200,20000)
module.frame.sf:Hide()
ELib:FixPreloadFont(module.frame,function()
if VMRT then
module.frame.text:SetFont(GameFontWhite:GetFont(),11,"")
module.frame:UpdateFont()
return true
end
end)
function module.frame:UpdateFont()
local font = VMRT and VMRT.Note and VMRT.Note.FontName or MRT.F.defFont
local size = VMRT and VMRT.Note and VMRT.Note.FontSize or 12
local outline = VMRT and VMRT.Note and VMRT.Note.Outline and "OUTLINE" or ""
local isValidFont = self.text:SetFont(font,size,outline)
local c = 2
while self["text"..c] do
self["text"..c]:SetFont(font,size,outline)
c = c + 1
end
if not isValidFont then
self.text:SetFont(GameFontNormal:GetFont(),size,outline)
local c = 2
while self["text"..c] do
self["text"..c]:SetFont(GameFontNormal:GetFont(),size,outline)
c = c + 1
end
end
end
MRT.F:RegisterCallback("CallbackRegistered", function(_,eventName)
if eventName == "Note_UpdateText" then
module.frame:UpdateText()
end
end)
MRT.F:RegisterCallback("CallbackUnregistered", function(_,eventName,_,callbacks)
if callbacks ~= 0 then
return
elseif eventName == "Note_UpdateText" then
module.frame:UpdateText()
end
end)
function module.frame:UpdateText(onlyTimerUpdate)
module.db.glowStatus = nil
local text
if VMRT.Note.ShowOnlyPersonal then
text = txtWithIcons("", onlyTimerUpdate)
else
text = txtWithIcons(VMRT.Note.Text1 or "", onlyTimerUpdate)
end
local c = 2
while self["text"..c] do
self["text"..c]:SetText(" ")
c = c + 1
end
if #text > 8192 then
local lennow = 0
local texts = {""}
local c = 1
for w in string.gmatch(text,"[^\n]+\n*") do
lennow = lennow + #w
if lennow > 8192 then
c = c + 1
texts[c] = ""
lennow = #w
end
texts[c] = texts[c] .. w
end
self.text:SetText(texts[1])
local anyNew = false
for i=2,c do
anyNew = module.frame.text:Add(i) or anyNew
module.frame["text"..i]:SetText(texts[i])
end
if anyNew then
module.frame:UpdateFont()
end
else
self.text:SetText(text)
end
if module.db.glowStatus and not self.GlowShowed then
module.frame:ShowGlow()
self.GlowShowed = true
elseif not module.db.glowStatus and self.GlowShowed then
module.frame:HideGlow()
self.GlowShowed = false
end
MRT.F:FireCallback("Note_UpdateText",self)
end
local glowColor = {0,1,0,1}
function module.frame:ShowGlow()
local LCG = LibStub("LibCustomGlow-1.0",true)
if not LCG then
return
end
if VMRT.Note.TimerGlowType == 2 then
LCG.ButtonGlow_Start(self)
elseif VMRT.Note.TimerGlowType == 3 then
LCG.AutoCastGlow_Start(self,glowColor,16,nil,2)
else
LCG.PixelGlow_Start(self,glowColor,nil,nil,nil,3,1,1)
end
end
function module.frame:HideGlow()
local LCG = LibStub("LibCustomGlow-1.0",true)
if LCG then
LCG.ButtonGlow_Stop(self)
LCG.AutoCastGlow_Stop(self)
LCG.PixelGlow_Stop(self)
end
end
module.frame.background = module.frame:CreateTexture(nil, "BACKGROUND")
module.frame.background:SetColorTexture(0, 0, 0, 1)
module.frame.background:SetAllPoints()
module.frame.red_back = CreateFrame("Frame",nil,module.frame)
module.frame.red_back:SetPoint("TOPLEFT",0,0)
module.frame.red_back:SetPoint("BOTTOMRIGHT",0,0)
module.frame.red_back.b = module.frame.red_back:CreateTexture(nil, "BACKGROUND", nil, 1)
module.frame.red_back.b:SetColorTexture(1, 0, 0, .2)
module.frame.red_back.b:SetAllPoints()
module.frame.red_back.s = ELib:Shadow(module.frame.red_back,20)
module.frame.red_back.s:SetBackdropBorderColor(1, 0, 0, .2)
module.frame.red_back:Hide()
local red_back_t = 1
module.frame.red_back:SetScript("OnShow",function()
red_back_t = 3
end)
module.frame.red_back:SetScript("OnUpdate",function(self,tmr)
red_back_t = red_back_t - tmr
if red_back_t <= 0 then
self:Hide()
return
end
self.s:SetBackdropBorderColor(1, 0, 0, max(0, .4 * min(2,red_back_t)/2))
self.b:SetColorTexture(1, 0, 0, max(0, .4 * min(2,red_back_t)/2))
end)
module.frame.text = module.frame:CreateFontString(nil,"ARTWORK")
module.frame.text:SetFont(MRT.F.defFont, 12, "")
module.frame.text:SetPoint("TOPLEFT",5,-5)
--module.frame.text:SetPoint("BOTTOMRIGHT",-5,5)
module.frame.text:SetPoint("TOPRIGHT",-5,-5)
module.frame.text:SetJustifyH("LEFT")
module.frame.text:SetJustifyV("TOP")
module.frame.text:SetText(" ")
function module.frame.text:FixLag()
self:SetParent(module.frame.sf.C)
self:ClearAllPoints()
self:SetPoint("TOPLEFT",5,-5)
--self:SetPoint("BOTTOMRIGHT",-5,5)
self:SetPoint("TOPRIGHT",-5,-5)
end
module.frame.sf:Show()
module.frame.text:FixLag()
module.frame.text:SetNonSpaceWrap(true)
function module.frame.text:Add(c)
if module.frame["text"..c] then
return
end
local text = module.frame:CreateFontString(nil,"ARTWORK")
module.frame["text"..c] = text
text:SetParent(module.frame.sf.C)
text:SetFont(MRT.F.defFont, 12, "")
local prev = c == 2 and module.frame.text or module.frame["text"..(c-1)]
text:SetPoint("TOPLEFT",prev,"BOTTOMLEFT",0,0)
text:SetPoint("TOPRIGHT",prev,"BOTTOMRIGHT",0,0)
text:SetJustifyH("LEFT")
text:SetJustifyV("TOP")
text:SetText(" ")
text:SetNonSpaceWrap(true)
return true
end
module.frame.buttonResize = CreateFrame("Frame",nil,module.frame)
module.frame.buttonResize:SetSize(15,15)
module.frame.buttonResize:SetPoint("BOTTOMRIGHT", 0, 0)
module.frame.buttonResize.back = module.frame.buttonResize:CreateTexture(nil, "BACKGROUND")
module.frame.buttonResize.back:SetTexture("Interface\\AddOns\\"..GlobalAddonName.."\\media\\Resize.tga")
module.frame.buttonResize.back:SetAllPoints()
module.frame.buttonResize:SetScript("OnMouseDown", function(self)
module.frame:StartSizing()
end)
module.frame.buttonResize:SetScript("OnMouseUp", function(self)
module.frame:StopMovingOrSizing()
end)
function module.frame:Save(blackNoteID)
VMRT.Note.Text1 = (blackNoteID and VMRT.Note.Black[blackNoteID] or VMRT.Note.Text1 or "")
MRT.F:FireCallback("Note_SendText",VMRT.Note.Text1)
if not blackNoteID and module.options.NoteEditBox and VMRT.Note.OptionsFormatting then
-- VMRT.Note.Text1 = VMRT.Note.Text1:gsub("|([Ttcr])","||%1")
end
if #VMRT.Note.Text1 == 0 then
VMRT.Note.Text1 = " "
end
local txttosand = VMRT.Note.Text1
local arrtosand = {}
local j = 1
local indextosnd = tostring(GetTime())..tostring(math.random(1000,9999))
for i=1,#txttosand do
if i%220 == 0 then
arrtosand[j]=string.sub (txttosand, (j-1)*220+1, j*220)
j = j + 1
elseif i == #txttosand then
arrtosand[j]=string.sub (txttosand, (j-1)*220+1)
j = j + 1
end
end
local encounterID = VMRT.Note.AutoLoad[blackNoteID or 0] or "-"
local noteName = (blackNoteID and VMRT.Note.BlackNames[blackNoteID]) or (not blackNoteID and VMRT.Note.DefName) or ""
if blackNoteID then
VMRT.Note.AutoLoad[0] = VMRT.Note.AutoLoad[blackNoteID]
VMRT.Note.DefName = VMRT.Note.BlackNames[blackNoteID]
if VMRT.Note.DefName then
VMRT.Note.DefName = VMRT.Note.DefName:gsub("%*$","")
end
end
if MRT.isClassic then
local MSG_LIMIT_COUNT = 10
local MSG_LIMIT_TIME = 6
if #arrtosand >= MSG_LIMIT_COUNT and module.options.buttonsend then
module.options.buttonsend:Disable()
C_Timer.After(floor((#arrtosand+1)/MSG_LIMIT_COUNT * MSG_LIMIT_TIME),function()
module.options.buttonsend:Enable()
end)
end
for i=1,#arrtosand,MSG_LIMIT_COUNT do
local start = i
C_Timer.After(floor((start-1)/MSG_LIMIT_COUNT) * MSG_LIMIT_TIME + 0.05,function()
for j=start,min(#arrtosand,start+MSG_LIMIT_COUNT-1) do
MRT.F.SendExMsg("multiline",indextosnd.."\t"..arrtosand[j])
end
end)
end
C_Timer.After(floor((#arrtosand)/MSG_LIMIT_COUNT) * MSG_LIMIT_TIME + 0.1,function()
MRT.F.SendExMsg("multiline_add",MRT.F.CreateAddonMsg(indextosnd,encounterID,noteName))
end)
else
for i=1,#arrtosand do
MRT.F.SendExMsg("multiline",indextosnd.."\t"..arrtosand[i])
end
MRT.F.SendExMsg("multiline_add",MRT.F.CreateAddonMsg(indextosnd,encounterID,noteName))
end
end
function module.frame:Clear()
module.options.NoteEditBox.EditBox:SetText("")
end
function module:addonMessage(sender, prefix, ...)
if prefix == "multiline" then
if VMRT.Note.OnlyPromoted and IsInRaid() and not MRT.F.IsPlayerRLorOfficer(sender) then
return
end
VMRT.Note.LastUpdateName = sender
VMRT.Note.LastUpdateTime = time()
local msgnowindex,lastnowtext = ...
if tostring(msgnowindex) == tostring(module.db.msgindex) then
module.db.lasttext = module.db.lasttext .. lastnowtext
else
module.db.lasttext = lastnowtext
end
module.db.msgindex = msgnowindex
VMRT.Note.Text1 = module.db.lasttext
MRT.F:FireCallback("Note_ReceivedText",VMRT.Note.Text1)
module.frame:UpdateText()
if module.options.NoteEditBox then
if module.options.IsMainNoteNow then
module.options.NoteEditBox.EditBox:SetText(VMRT.Note.Text1)
end
module.options.lastUpdate:SetText( L.NoteLastUpdate..": "..VMRT.Note.LastUpdateName.." ("..date("%H:%M:%S %d.%m.%Y",VMRT.Note.LastUpdateTime)..")" )
end
VMRT.Note.AutoLoad[0] = nil
if module.options.UpdatePageAfterGettingNote then
module.options.UpdatePageAfterGettingNote()
end
if VMRT.Note.EnableWhenReceive and not VMRT.Note.enabled then
module:Enable()
end
module.frame.red_back:Show()
if type(WeakAuras)=="table" and WeakAuras.ScanEvents and type(WeakAuras.ScanEvents)=="function" then
WeakAuras.ScanEvents("EXRT_NOTE_UPDATE")
WeakAuras.ScanEvents("MRT_NOTE_UPDATE")
end
elseif prefix == "multiline_add" then
if VMRT.Note.OnlyPromoted and IsInRaid() and not MRT.F.IsPlayerRLorOfficer(sender) then
return
end
if sender == MRT.SDB.charKey then
return
end
local msgIndex,encounterID,noteName = ...
if tostring(msgIndex) ~= tostring(module.db.msgindex) then
return
end
encounterID = tonumber(encounterID)
if noteName == "" then noteName = nil end
VMRT.Note.AutoLoad[0] = encounterID
VMRT.Note.DefName = noteName
if VMRT.Note.SaveAllNew then
local finded = false
if noteName then
noteName = noteName:gsub("%*+$","").."*"
for i=1,#VMRT.Note.Black do
if VMRT.Note.BlackNames[i] == noteName and VMRT.Note.AutoLoad[i] == encounterID then
VMRT.Note.Black[i] = VMRT.Note.Text1
VMRT.Note.AutoLoad[i] = encounterID
VMRT.Note.BlackLastUpdateName[i] = sender
VMRT.Note.BlackLastUpdateTime[i] = time()
finded = true
break
end
end
elseif encounterID then
for i=1,#VMRT.Note.Black do
if VMRT.Note.AutoLoad[i] == encounterID and (not VMRT.Note.BlackNames[i] or VMRT.Note.BlackNames[i] == "") then
VMRT.Note.Black[i] = VMRT.Note.Text1
VMRT.Note.BlackLastUpdateName[i] = sender
VMRT.Note.BlackLastUpdateTime[i] = time()
finded = true
break
end
end
end
if not finded then
local newIndex = #VMRT.Note.Black + 1
VMRT.Note.Black[newIndex] = VMRT.Note.Text1
VMRT.Note.AutoLoad[newIndex] = encounterID
VMRT.Note.BlackNames[newIndex] = noteName
VMRT.Note.BlackLastUpdateName[newIndex] = sender
VMRT.Note.BlackLastUpdateTime[newIndex] = time()
if module.options.NotesListUpdateNames then
module.options.NotesListUpdateNames()
end
end
end
if module.options.UpdatePageAfterGettingNote then
module.options.UpdatePageAfterGettingNote()
end
elseif prefix == "multiline_timer_sync" then
local name = ...
MRT.F.Note_Timer(name)
end
end
local gruevent = {}
function module.main:ADDON_LOADED()
VMRT = _G.VMRT
VMRT.Note = VMRT.Note or {
OnlyPromoted = true,
OptionsFormatting = true,
}
VMRT.Note.Black = VMRT.Note.Black or {}
VMRT.Note.AutoLoad = VMRT.Note.AutoLoad or {}
if VMRT.Note.Left and VMRT.Note.Top then
module.frame:ClearAllPoints()
module.frame:SetPoint("TOPLEFT",UIParent,"BOTTOMLEFT",VMRT.Note.Left,VMRT.Note.Top)
end
VMRT.Note.FontSize = VMRT.Note.FontSize or 12
if VMRT.Note.Width then
module.frame:SetWidth(VMRT.Note.Width)
end
if VMRT.Note.Height then
module.frame:SetHeight(VMRT.Note.Height)
end
module.frame:UpdateFont()
if VMRT.Note.enabled then
module:Enable()
end
C_Timer.After(5,function()
module.frame:UpdateFont()
end)
if VMRT.Note.Text1 then
module.frame:UpdateText()
end
if VMRT.Note.Alpha then
module.frame:SetAlpha(VMRT.Note.Alpha/100)
end
if VMRT.Note.Scale then
module.frame:SetScale(VMRT.Note.Scale/100)
end
if VMRT.Note.ScaleBack then
module.frame.background:SetColorTexture(0, 0, 0, VMRT.Note.ScaleBack/100)
end
if VMRT.Note.Fix then
module.frame:SetMovable(false)
module.frame:EnableMouse(false)
module.frame.buttonResize:Hide()
else
MRT.lib.AddShadowComment(module.frame,nil,L.message)
end
VMRT.Note.BlackNames = VMRT.Note.BlackNames or {}
for i=1,3 do
VMRT.Note.Black[i] = VMRT.Note.Black[i] or ""
end
VMRT.Note.BlackLastUpdateName = VMRT.Note.BlackLastUpdateName or {}
VMRT.Note.BlackLastUpdateTime = VMRT.Note.BlackLastUpdateTime or {}
VMRT.Note.Strata = VMRT.Note.Strata or "HIGH"
module:RegisterAddonMessage()
module:RegisterSlash()
module.frame:SetFrameStrata(VMRT.Note.Strata)
end
function module.main:PLAYER_LOGIN()
if VMRT.Note.enabled then
module.frame:UpdateText()
end
end
function module:Enable()
VMRT.Note.enabled = true
if module.options.chkEnable then
module.options.chkEnable:SetChecked(true)
end
module:RegisterEvents("PLAYER_SPECIALIZATION_CHANGED","PLAYER_LOGIN","ENCOUNTER_END","ENCOUNTER_START")
if VMRT.Note.HideOutsideRaid then
module:RegisterEvents("GROUP_ROSTER_UPDATE")
end
if VMRT.Note.HideInCombat then
module:RegisterEvents('PLAYER_REGEN_DISABLED','PLAYER_REGEN_ENABLED')
end
if VMRT.Note.ShowOnlyInRaid then
module:RegisterEvents('ZONE_CHANGED_NEW_AREA')
end
module:Visibility()
GSUB_AutoColorCreate()
end
function module:Disable()
VMRT.Note.enabled = nil
if module.options.chkEnable then
module.options.chkEnable:SetChecked(false)
end
module:UnregisterEvents('PLAYER_REGEN_DISABLED','PLAYER_REGEN_ENABLED','ZONE_CHANGED_NEW_AREA',"PLAYER_SPECIALIZATION_CHANGED","PLAYER_LOGIN","ENCOUNTER_END","ENCOUNTER_START")
module:Visibility()
end
local Note_CombatState = false
function module:Visibility()
local bool = true
if not VMRT.Note.enabled then
bool = bool and false
end
if bool and VMRT.Note.HideOutsideRaid then
if GetNumGroupMembers() > 0 then
bool = bool and true
else
bool = bool and false
end
end
if bool and VMRT.Note.HideInCombat then
if Note_CombatState then
bool = bool and false
else
bool = bool and true
end
end
if bool and VMRT.Note.ShowOnlyInRaid then
local _,zoneType = IsInInstance()
if zoneType == "raid" then
bool = bool and true
else
bool = bool and false
end
end
if bool then
module.frame:Show()
else
module.frame:Hide()
end
end
local party_uids = {'player','party1','party2','party3','party4'}
function module.main:GROUP_ROSTER_UPDATE()
C_Timer.After(1, module.Visibility)
GSUB_AutoColorCreate()
if not module.options.raidnames or not module.options:IsVisible() then
return
end
for i=1,8 do gruevent[i] = 0 end
for _,name,subgroup,class in MRT.F.IterateRoster do
gruevent[subgroup] = gruevent[subgroup] + 1
local cR,cG,cB = MRT.F.classColorNum(class)
local POS = gruevent[subgroup] + (subgroup - 1) * 5
local obj = module.options.raidnames[POS]
if obj then
name = MRT.F.delUnitNameServer(name)
local colorCode = MRT.F.classColor(class)
obj.iconText = "||c"..colorCode..name.."||r "
obj.iconTextShift = name
obj.html:SetText(name)
obj.html:SetTextColor(cR, cG, cB, 1)
end
end
for i=1,8 do
for j=(gruevent[i]+1),5 do
local frame = module.options.raidnames[(i-1)*5+j]
frame.iconText = ""
frame.iconTextShift = ""
frame.html:SetText("")
end
end
end
function module.main:PLAYER_REGEN_DISABLED()
Note_CombatState = true
module:Visibility()
end
function module.main:PLAYER_REGEN_ENABLED()
Note_CombatState = false
module:Visibility()
end
function module.main:ZONE_CHANGED_NEW_AREA()
C_Timer.After(5, module.Visibility)
end
function module.main:PLAYER_SPECIALIZATION_CHANGED(unit)
if unit == "player" then
module.frame:UpdateText()
end
end
do
local BossPhasesBossmodAdded
local function BossPhasesBossmod()
if BossPhasesBossmodAdded then
return
end
if type(BigWigsLoader)=='table' and BigWigsLoader.RegisterMessage then
BigWigsLoader.RegisterMessage({}, "BigWigs_SetStage", function(event, addon, stage)
if stage then
wipe(encounter_time_p)
local t = GetTime()
encounter_time_p[stage] = t
encounter_time_p[tostring(stage)] = t
if module.frame:IsShown() then
module.frame:UpdateText()
end
end
end)
BossPhasesBossmodAdded = true
elseif type(DBM)=='table' and DBM.RegisterCallback then
DBM:RegisterCallback("DBM_SetStage", function(event, addon, modId, stage, encounterId, globalStage)
if stage then
wipe(encounter_time_p)
local t = GetTime()
encounter_time_p[stage] = t
encounter_time_p[tostring(stage)] = t
if globalStage then
encounter_time_p["g"..tostring(globalStage)] = t
end
if module.frame:IsShown() then
module.frame:UpdateText()
end
end
end)
BossPhasesBossmodAdded = true
end
end
local phaseCombatEvents = {}
function module.main:ENCOUNTER_START(encounterID, encounterName, difficultyID, groupSize)
local noteText = (VMRT.Note.Text1 or "")..(VMRT.Note.SelfText or "")
if encounterID and encounterName then
encounter_id[tostring(encounterID)] = true
encounter_id[encounterName] = true
end
local timeInText = noteText:find("{time:([0-9:]+[^{}]*)}")
local phaseInText = noteText:find("{[Pp]([^}:][^}]*)}(.-){/[Pp]}")
if timeInText or (phaseInText and ((type(BigWigsLoader)=='table') or (type(DBM)=='table'))) then
wipe(encounter_time_c)
wipe(encounter_time_wa_uids)
module.db.encounter_time = GetTime()
encounter_time_p[1] = module.db.encounter_time
encounter_time_p["1"] = module.db.encounter_time
BossPhasesBossmod()
wipe(module.db.encounter_counters.SCC)
wipe(module.db.encounter_counters.SCS)
wipe(module.db.encounter_counters.SAA)
wipe(module.db.encounter_counters.SAR)
if timeInText then
module:RegisterTimer()
end
local anyEvent
string_gsub(noteText,"{time:[0-9:]+[^}]*,(S[^{},]+)[,}]",function(str)
local event,spellID,count = strsplit(":",str)
if tonumber(count or "") and tonumber(spellID or "") and event and module.db.encounter_counters[event] then
anyEvent = true
module.db.encounter_counters[event][tonumber(spellID)] = 0
end
end)
wipe(phaseCombatEvents)
string_gsub(noteText,"{[Pp],(S[^{},]+),?(S?[^{},]*)[,}]",function(str1,str2)
for _,str in pairs({str1,str2}) do
if str ~= "" then
local event,spellID,count = strsplit(":",str)
if tonumber(count or "") and tonumber(spellID or "") and event and module.db.encounter_counters[event] then
anyEvent = true
module.db.encounter_counters[event][tonumber(spellID)] = 0
phaseCombatEvents[str] = true
end
end
end
end)
if anyEvent then
wipe(module.db.encounter_counters_time)
module:RegisterEvents("COMBAT_LOG_EVENT_UNFILTERED")
end
end
module.frame:UpdateText()
end
function module.main:ENCOUNTER_END()
wipe(encounter_id)
module:UnregisterTimer()
module.db.encounter_time = nil
wipe(encounter_time_p)
wipe(encounter_time_c)
wipe(encounter_time_wa_uids)
module:UnregisterEvents("COMBAT_LOG_EVENT_UNFILTERED")
wipe(module.db.encounter_counters.SCC)
wipe(module.db.encounter_counters.SCS)
wipe(module.db.encounter_counters.SAA)
wipe(module.db.encounter_counters.SAR)
wipe(module.db.encounter_counters_time)
module.frame:UpdateText()
end
local tmr = 0
function module:timer(elapsed)
tmr = tmr + elapsed
if tmr > 1 then
tmr = 0
if module.frame:IsShown() then
module.frame:UpdateText(true)
end
end
end
module.db.encounter_counters_time = {}
module.db.encounter_counters = {
SCC = {},
SCS = {},
SAA = {},
SAR = {},
}
local ECT = module.db.encounter_counters_time
local SCC = module.db.encounter_counters.SCC
local SCS = module.db.encounter_counters.SCS
local SAA = module.db.encounter_counters.SAA
local SAR = module.db.encounter_counters.SAR
local function AddCounter(table,tableName,spellID)
table[spellID] = table[spellID] + 1
local key_w_counter = tableName..":"..spellID..":"..table[spellID]
local key_wo_counter = tableName..":"..spellID..":"..0
local t = GetTime()
ECT[ key_w_counter ] = t
ECT[ key_wo_counter ] = t
if phaseCombatEvents[key_w_counter] or phaseCombatEvents[key_wo_counter] then
if module.frame:IsShown() then
module.frame:UpdateText()
end
end
end
function module.main.COMBAT_LOG_EVENT_UNFILTERED(_,event,_,_,_,_,_,_,_,_,_,spellID)
if event == "SPELL_CAST_SUCCESS" then
if SCC[spellID] then
return AddCounter(SCC,"SCC",spellID)
end
elseif event == "SPELL_CAST_START" then
if SCS[spellID] then
return AddCounter(SCS,"SCS",spellID)
end
elseif event == "SPELL_AURA_APPLIED" then
if SAA[spellID] then
return AddCounter(SAA,"SAA",spellID)
end
elseif event == "SPELL_AURA_REMOVED" then
if SAR[spellID] then
return AddCounter(SAR,"SAR",spellID)
end
end
end
function MRT.F.Note_Timer(name)
if not name then
return
end
if not module.db.encounter_time then
module.main:ENCOUNTER_START()
end
encounter_time_c[name] = GetTime()
end
function MRT.F.Note_SyncTimer(name)
if not name then
return
end
MRT.F.SendExMsg("multiline_timer_sync",name)
end
end
function module:slash(arg)
if arg == "note" or arg == "n" then
if VMRT.Note.enabled then
module:Disable()
else
module:Enable()
end
elseif arg == "editnote" or arg == "edit note" then
MRT.Options:Open(module.options)
elseif arg == "note timer" then
if module.db.encounter_time then
module.main:ENCOUNTER_END()
print('timer ended')
else
module.main:ENCOUNTER_START()
print('timer started')
end
elseif arg and arg:find("^note starttimer ") then
local timer = arg:match("^note starttimer (.-)$")
if timer then
MRT.F.Note_Timer(timer)
end
elseif arg and arg:find("^note synctimer ") then
local timer = arg:match("^note synctimer (.-)$")
if timer then
MRT.F.Note_SyncTimer(timer)
end
elseif arg and arg:find("^note set ") then
local name = arg:match("^note set (.-)$")
if name then
local nameNumber = tonumber(name)
for i=1,#VMRT.Note.Black do
local blackName = VMRT.Note.BlackNames[i]
if (blackName and blackName:lower() == name) or (nameNumber == i) then
module.frame:Save(i)
return
end
end
end
elseif arg and arg:find("^note phase ") then
local phase = arg:match("^note phase (.-)$")
if phase then
wipe(encounter_time_p)
encounter_time_p[phase] = GetTime()
print("Set phase",phase)
if module.frame:IsShown() then
module.frame:UpdateText()
end
end
elseif arg == "help" then
print("|cff00ff00/rt note|r - hide/show note")
print("|cff00ff00/rt editnote|r - open notes tab")
print("|cff00ff00/rt note set |cffffff00NOTENAME|r|r - set & send note with NOTENAME name")
print("|cff00ff00/rt note timer|r - simulate boss encounter start [for timers feature]")
print("|cff00ff00/rt note starttimer |cffffff00TIMERNAME|r|r - start custom timer")
end
end
function module:GetText(removeColors,removeExtraSpaces)
local text = VMRT.Note.Text1 or ""
if removeColors then
text = text:gsub("|c........",""):gsub("|r","")
end
if removeExtraSpaces then
text = text:gsub(" *\n","\n"):gsub(" *$",""):gsub(" +"," ")
end
return text
end
MRT.F.GetNote = module.GetText
5 years ago
--- you can use to get note text GMRT.F:GetNote()