Compare commits
57 Commits
github-act
...
main
Author | SHA1 | Date | |
---|---|---|---|
|
ff619e7228 | ||
|
8bd027c614 | ||
|
393af7875d | ||
|
468cbf24f3 | ||
|
50987addb5 | ||
|
7930335294 | ||
|
535fedab1a | ||
|
6be69bc51c | ||
|
5f8807a879 | ||
|
c122e24054 | ||
|
47bc4d46f4 | ||
|
cacd83479c | ||
|
117888cdb0 | ||
|
8f4f153011 | ||
|
b72b2a3c3a | ||
|
387f12a97e | ||
|
892b5e8a59 | ||
|
ab51106301 | ||
|
6f5ab94ecb | ||
|
86fcff8ea8 | ||
|
0759357e72 | ||
|
ff703a0bc8 | ||
|
16d5541ad9 | ||
|
b8f004033b | ||
|
3b285efa9e | ||
|
e4cc5568ce | ||
|
fc7042ca87 | ||
|
261dc8b755 | ||
|
971016e249 | ||
|
8b766c23d2 | ||
|
afd5647807 | ||
|
ed0b601467 | ||
|
a4ee8219a6 | ||
|
8e97bb32c6 | ||
|
d385692cdc | ||
|
9c4eed673f | ||
|
4b5ec6767f | ||
|
88959d988c | ||
|
fe1b613aac | ||
|
39d730116f | ||
|
342be5dcd0 | ||
|
045d734945 | ||
|
f29985a06e | ||
|
70acab71e9 | ||
|
048fbb55e7 | ||
|
e45118484b | ||
|
709cc7fd86 | ||
|
b714c065f6 | ||
|
6161fcc7e3 | ||
|
51143988be | ||
|
8442bfd1df | ||
|
5f5b0841fc | ||
|
9d03fa5ff3 | ||
|
bc40bbce0a | ||
|
391e149b6d | ||
|
128f32f57f | ||
|
9ce0bbc32a |
48
.github/workflows/release.yml
vendored
48
.github/workflows/release.yml
vendored
@ -1,48 +0,0 @@
|
|||||||
# description of this workflow, can be anything you want
|
|
||||||
name: Package and release
|
|
||||||
|
|
||||||
# we need to let GitHub know _when_ we want to release, typically only when we create a new tag.
|
|
||||||
# this will target only tags, and not all pushes to the master branch.
|
|
||||||
# this part can be heavily customized to your liking, like targeting only tags that match a certain word,
|
|
||||||
# other branches or even pullrequests.
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
tags:
|
|
||||||
- '**'
|
|
||||||
-
|
|
||||||
# Allows you to run this workflow manually from the Actions tab
|
|
||||||
workflow_dispatch:
|
|
||||||
|
|
||||||
# a workflow is built up as jobs, and within these jobs are steps
|
|
||||||
jobs:
|
|
||||||
|
|
||||||
# "release" is a job, you can name it anything you want
|
|
||||||
release:
|
|
||||||
|
|
||||||
# we can run our steps on pretty much anything, but the "ubuntu-latest" image is a safe bet
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
# specify the environment variables used by the packager, matching the secrets from the project on GitHub
|
|
||||||
env:
|
|
||||||
GITHUB_OAUTH: ${{ secrets.GITHUB_TOKEN }} # "GITHUB_TOKEN" is a secret always provided to the workflow
|
|
||||||
# for your own token, the name cannot start with "GITHUB_"
|
|
||||||
|
|
||||||
# "steps" holds a list of all the steps needed to package and release our AddOn
|
|
||||||
steps:
|
|
||||||
|
|
||||||
# we first have to clone the AddOn project, this is a required step
|
|
||||||
- name: Clone project
|
|
||||||
uses: actions/checkout@v3
|
|
||||||
with:
|
|
||||||
fetch-depth: 0 # gets git history for changelogs
|
|
||||||
|
|
||||||
# once cloned, we just run the GitHub Action for the packager project
|
|
||||||
- name: Package and release
|
|
||||||
uses: BigWigsMods/packager@v2
|
|
||||||
|
|
||||||
# another example where we supply additional arguments, this example is specifically to release
|
|
||||||
# for the Burning Crusade Classic version of the game and doesn't upload to WoWInterface
|
|
||||||
- name: Package and release for Burning Crusade Classic
|
|
||||||
uses: BigWigsMods/packager@v2
|
|
||||||
with:
|
|
||||||
args: -g bcc -w 0
|
|
1
.gitignore
vendored
1
.gitignore
vendored
@ -6,5 +6,6 @@ BuffLib
|
|||||||
Ace-Libs
|
Ace-Libs
|
||||||
Images_Raw
|
Images_Raw
|
||||||
Gladdy_old
|
Gladdy_old
|
||||||
|
DoNotCommit
|
||||||
untracked
|
untracked
|
||||||
Gladdy_TW
|
Gladdy_TW
|
10
.pkgmeta
10
.pkgmeta
@ -1,10 +0,0 @@
|
|||||||
package-as: Gladdy
|
|
||||||
|
|
||||||
enable-nolib-creation: no
|
|
||||||
|
|
||||||
embedded-libraries:
|
|
||||||
- drlist-1-0
|
|
||||||
|
|
||||||
manual-changelog:
|
|
||||||
filename: CHANGELOG.md
|
|
||||||
markup-type: markdown
|
|
24
CHANGELOG.md
24
CHANGELOG.md
@ -1,24 +0,0 @@
|
|||||||
### v2.20-Beta
|
|
||||||
- **Wrath** & **BCC** support
|
|
||||||
- different auras/DRs/Cooldowns/Buffs per expansion
|
|
||||||
- **Zoomed Icon** options added for all modules
|
|
||||||
- **Cooldowns**
|
|
||||||
- desaturate icon on cd added
|
|
||||||
- alpha on cd added
|
|
||||||
- glow on CD active added
|
|
||||||
- **Diminishing**
|
|
||||||
- replaced DRData with DRList (your dr-categories options will be reset like "force icon" and what is enabled)
|
|
||||||
- zoomed icons
|
|
||||||
- changed DR-tracking behaviour (DR will show once aura is applied and start CD once aura fades)
|
|
||||||
- **Trinket & Racial**
|
|
||||||
- in Wrath racials like wotf share CD with Trinket and vice versa
|
|
||||||
- fixed some potential API bug in Trinket use detection
|
|
||||||
- **ArenaCountdown**
|
|
||||||
- uses C_Timer now
|
|
||||||
- **Import/Export of Profiles**
|
|
||||||
- profiles should now be able to import/export between BCC and Wrath
|
|
||||||
- auras, cooldowns, DRs and buffs/debuffs are ignored
|
|
||||||
- positioning, style etc will be transferred between expansions
|
|
||||||
- proper Feign Death detection
|
|
||||||
- fix detect pet abilities CD like Spell Lock
|
|
||||||
- minor bugfixes
|
|
@ -626,7 +626,7 @@ local importantAuras = {
|
|||||||
spellID = 24259,
|
spellID = 24259,
|
||||||
},
|
},
|
||||||
-- Unstable Affliction Silence
|
-- Unstable Affliction Silence
|
||||||
["Unstable Affliction Silence"] = { -- GetSpellInfo returns "Unstable Affliction"
|
[select(1, GetSpellInfo(31117)) .. " Silence"] = { -- GetSpellInfo returns "Unstable Affliction"
|
||||||
track = AURA_TYPE_DEBUFF,
|
track = AURA_TYPE_DEBUFF,
|
||||||
altName = select(1, GetSpellInfo(31117)) .. " Silence",
|
altName = select(1, GetSpellInfo(31117)) .. " Silence",
|
||||||
duration = 5,
|
duration = 5,
|
||||||
@ -759,9 +759,9 @@ local importantAuras = {
|
|||||||
},
|
},
|
||||||
-- Shadowsight Buff
|
-- Shadowsight Buff
|
||||||
[GetSpellInfo(34709)] = {
|
[GetSpellInfo(34709)] = {
|
||||||
track = AURA_TYPE_BUFF,
|
track = AURA_TYPE_DEBUFF,
|
||||||
duration = 15,
|
duration = 15,
|
||||||
priority = 15,
|
priority = 9,
|
||||||
magic = true,
|
magic = true,
|
||||||
spellID = 34709,
|
spellID = 34709,
|
||||||
},
|
},
|
||||||
@ -978,7 +978,7 @@ local cooldownList = {
|
|||||||
icon = select(3, GetSpellInfo(14311)),
|
icon = select(3, GetSpellInfo(14311)),
|
||||||
},
|
},
|
||||||
[34490] = { cd = 20, spec = L["Marksmanship"], }, -- Silencing Shot
|
[34490] = { cd = 20, spec = L["Marksmanship"], }, -- Silencing Shot
|
||||||
[19386] = { cd = 60, spec = L["Survival"], }, -- Wyvern Sting
|
[19386] = { cd = 120, spec = L["Survival"], }, -- Wyvern Sting
|
||||||
[19577] = { cd = 60, spec = L["Beast Mastery"], }, -- Intimidation
|
[19577] = { cd = 60, spec = L["Beast Mastery"], }, -- Intimidation
|
||||||
[34471] = { cd = 120, spec = L["Beast Mastery"], }, -- The Beast Within
|
[34471] = { cd = 120, spec = L["Beast Mastery"], }, -- The Beast Within
|
||||||
[5384] = 30, -- Feign Death
|
[5384] = 30, -- Feign Death
|
||||||
@ -1121,333 +1121,55 @@ end
|
|||||||
|
|
||||||
local totemData = {
|
local totemData = {
|
||||||
-- Fire
|
-- Fire
|
||||||
[string_lower("Searing Totem")] = {id = 3599,texture = select(3, GetSpellInfo(3599)), color = {r = 0, g = 0, b = 0, a = 1}},
|
|
||||||
[string_lower("Flametongue Totem")] = {id = 8227,texture = select(3, GetSpellInfo(8227)), color = {r = 0, g = 0, b = 0, a = 1}},
|
|
||||||
[string_lower("Magma Totem")] = {id = 8190,texture = select(3, GetSpellInfo(8190)), color = {r = 0, g = 0, b = 0, a = 1}, pulse = 2},
|
|
||||||
[string_lower("Fire Nova Totem")] = {id = 1535,texture = select(3, GetSpellInfo(1535)), color = {r = 0, g = 0, b = 0, a = 1}, pulse = { cd = 4, once = true }},
|
|
||||||
[string_lower("Totem of Wrath")] = {id = 30706,texture = select(3, GetSpellInfo(30706)), color = {r = 0, g = 0, b = 0, a = 1}},
|
|
||||||
[string_lower("Fire Elemental Totem")] = {id = 32982,texture = select(3, GetSpellInfo(32982)), color = {r = 0, g = 0, b = 0, a = 1}},
|
|
||||||
[string_lower("Frost Resistance Totem")] = {id = 8181,texture = select(3, GetSpellInfo(8181)), color = {r = 0, g = 0, b = 0, a = 1}},
|
|
||||||
-- Water
|
-- Water
|
||||||
[string_lower("Fire Resistance Totem")] = {id = 8184,texture = select(3, GetSpellInfo(8184)), color = {r = 0, g = 0, b = 0, a = 1}},
|
|
||||||
[string_lower("Poison Cleansing Totem")] = {id = 8166,texture = select(3, GetSpellInfo(8166)), color = {r = 0, g = 0, b = 0, a = 1}, pulse = 5},
|
[string_lower("Poison Cleansing Totem")] = {id = 8166,texture = select(3, GetSpellInfo(8166)), color = {r = 0, g = 0, b = 0, a = 1}, pulse = 5},
|
||||||
[string_lower("Disease Cleansing Totem")] = {id = 8170,texture = select(3, GetSpellInfo(8170)), color = {r = 0, g = 0, b = 0, a = 1}, pulse = 5},
|
|
||||||
[string_lower("Healing Stream Totem")] = {id = 5394,texture = select(3, GetSpellInfo(5394)), color = {r = 0, g = 0, b = 0, a = 1}, pulse = 2},
|
|
||||||
[string_lower("Mana Tide Totem")] = {id = 16190,texture = select(3, GetSpellInfo(16190)), color = {r = 0.078, g = 0.9, b = 0.16, a = 1}},
|
|
||||||
[string_lower("Mana Spring Totem")] = {id = 5675,texture = select(3, GetSpellInfo(5675)), color = {r = 0, g = 0, b = 0, a = 1}, pulse = 2},
|
[string_lower("Mana Spring Totem")] = {id = 5675,texture = select(3, GetSpellInfo(5675)), color = {r = 0, g = 0, b = 0, a = 1}, pulse = 2},
|
||||||
-- Earth
|
-- Earth
|
||||||
[string_lower("Earthbind Totem")] = {id = 2484,texture = select(3, GetSpellInfo(2484)), color = {r = 0.5, g = 0.5, b = 0.5, a = 1}, pulse = 3},
|
|
||||||
[string_lower("Stoneclaw Totem")] = {id = 5730,texture = select(3, GetSpellInfo(5730)), color = {r = 0, g = 0, b = 0, a = 1}, pulse = 2},
|
|
||||||
[string_lower("Stoneskin Totem")] = {id = 8071,texture = select(3, GetSpellInfo(8071)), color = {r = 0, g = 0, b = 0, a = 1}},
|
|
||||||
[string_lower("Strength of Earth Totem")] = {id = 8075,texture = select(3, GetSpellInfo(8075)), color = {r = 0, g = 0, b = 0, a = 1}},
|
|
||||||
[string_lower("Earth Elemental Totem")] = {id = 33663,texture = select(3, GetSpellInfo(33663)), color = {r = 0, g = 0, b = 0, a = 1}},
|
|
||||||
[string_lower("Tremor Totem")] = {id = 8143,texture = select(3, GetSpellInfo(8143)), color = {r = 1, g = 0.9, b = 0.1, a = 1}, pulse = 3},
|
|
||||||
-- Air
|
-- Air
|
||||||
[string_lower("Grounding Totem")] = {id = 8177,texture = select(3, GetSpellInfo(8177)), color = {r = 0, g = 0.53, b = 0.92, a = 1}},
|
|
||||||
[string_lower("Grace of Air Totem")] = {id = 8835,texture = select(3, GetSpellInfo(8835)), color = {r = 0, g = 0, b = 0, a = 1}},
|
[string_lower("Grace of Air Totem")] = {id = 8835,texture = select(3, GetSpellInfo(8835)), color = {r = 0, g = 0, b = 0, a = 1}},
|
||||||
[string_lower("Nature Resistance Totem")] = {id = 10595,texture = select(3, GetSpellInfo(10595)), color = {r = 0, g = 0, b = 0, a = 1}},
|
|
||||||
[string_lower("Windfury Totem")] = {id = 8512,texture = select(3, GetSpellInfo(8512)), color = {r = 0.96, g = 0, b = 0.07, a = 1}},
|
|
||||||
[string_lower("Sentry Totem")] = {id = 6495, texture = select(3, GetSpellInfo(6495)), color = {r = 0, g = 0, b = 0, a = 1}},
|
|
||||||
[string_lower("Windwall Totem")] = {id = 15107,texture = select(3, GetSpellInfo(15107)), color = {r = 0, g = 0, b = 0, a = 1}},
|
[string_lower("Windwall Totem")] = {id = 15107,texture = select(3, GetSpellInfo(15107)), color = {r = 0, g = 0, b = 0, a = 1}},
|
||||||
[string_lower("Wrath of Air Totem")] = {id = 3738,texture = select(3, GetSpellInfo(3738)), color = {r = 0, g = 0, b = 0, a = 1}},
|
|
||||||
[string_lower("Tranquil Air Totem")] = {id = 25908,texture = select(3, GetSpellInfo(25908)), color = {r = 0, g = 0, b = 0, a = 1}},
|
[string_lower("Tranquil Air Totem")] = {id = 25908,texture = select(3, GetSpellInfo(25908)), color = {r = 0, g = 0, b = 0, a = 1}},
|
||||||
}
|
}
|
||||||
|
|
||||||
local totemSpellIdToPulse = {
|
local totemSpellIdToPulse = {
|
||||||
[GetSpellInfo(totemData[string_lower("Earthbind Totem")].id)] = totemData[string_lower("Earthbind Totem")].pulse,
|
|
||||||
[2484] = totemData[string_lower("Earthbind Totem")].pulse,
|
|
||||||
[GetSpellInfo(totemData[string_lower("Tremor Totem")].id)] = totemData[string_lower("Tremor Totem")].pulse,
|
|
||||||
[8143] = totemData[string_lower("Tremor Totem")].pulse,
|
|
||||||
[GetSpellInfo(totemData[string_lower("Poison Cleansing Totem")].id)] = totemData[string_lower("Poison Cleansing Totem")].pulse,
|
[GetSpellInfo(totemData[string_lower("Poison Cleansing Totem")].id)] = totemData[string_lower("Poison Cleansing Totem")].pulse,
|
||||||
[8166] = totemData[string_lower("Poison Cleansing Totem")].pulse,
|
[8166] = totemData[string_lower("Poison Cleansing Totem")].pulse,
|
||||||
[GetSpellInfo(totemData[string_lower("Disease Cleansing Totem")].id)] = totemData[string_lower("Disease Cleansing Totem")].pulse,
|
|
||||||
[8170] = totemData[string_lower("Disease Cleansing Totem")].pulse,
|
|
||||||
[GetSpellInfo(totemData[string_lower("Fire Nova Totem")].id)] = totemData[string_lower("Fire Nova Totem")].pulse,
|
|
||||||
[1535] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 1
|
|
||||||
[8498] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 2
|
|
||||||
[8499] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 3
|
|
||||||
[11314] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 4
|
|
||||||
[11315] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 5
|
|
||||||
[25546] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 6
|
|
||||||
[25547] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 7
|
|
||||||
[GetSpellInfo(totemData[string_lower("Magma Totem")].id)] = totemData[string_lower("Magma Totem")].pulse,
|
|
||||||
[8190] = totemData[string_lower("Magma Totem")].pulse, -- Rank 1
|
|
||||||
[10585] = totemData[string_lower("Magma Totem")].pulse, -- Rank 2
|
|
||||||
[10586] = totemData[string_lower("Magma Totem")].pulse, -- Rank 3
|
|
||||||
[10587] = totemData[string_lower("Magma Totem")].pulse, -- Rank 4
|
|
||||||
[25552] = totemData[string_lower("Magma Totem")].pulse, -- Rank 5
|
|
||||||
[GetSpellInfo(totemData[string_lower("Healing Stream Totem")].id)] = totemData[string_lower("Healing Stream Totem")].pulse,
|
|
||||||
[5394] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 1
|
|
||||||
[6375] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 2
|
|
||||||
[6377] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 3
|
|
||||||
[10462] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 4
|
|
||||||
[10463] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 5
|
|
||||||
[25567] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 6
|
|
||||||
[GetSpellInfo(totemData[string_lower("Mana Spring Totem")].id)] = totemData[string_lower("Mana Spring Totem")].pulse,
|
[GetSpellInfo(totemData[string_lower("Mana Spring Totem")].id)] = totemData[string_lower("Mana Spring Totem")].pulse,
|
||||||
[5675] = totemData[string_lower("Mana Spring Totem")].pulse, -- Rank 1
|
[5675] = totemData[string_lower("Mana Spring Totem")].pulse, -- Rank 1
|
||||||
[10495] = totemData[string_lower("Mana Spring Totem")].pulse, -- Rank 2
|
[10495] = totemData[string_lower("Mana Spring Totem")].pulse, -- Rank 2
|
||||||
[10496] = totemData[string_lower("Mana Spring Totem")].pulse, -- Rank 3
|
[10496] = totemData[string_lower("Mana Spring Totem")].pulse, -- Rank 3
|
||||||
[10497] = totemData[string_lower("Mana Spring Totem")].pulse, -- Rank 4
|
[10497] = totemData[string_lower("Mana Spring Totem")].pulse, -- Rank 4
|
||||||
[25570] = totemData[string_lower("Mana Spring Totem")].pulse, -- Rank 5
|
[25570] = totemData[string_lower("Mana Spring Totem")].pulse, -- Rank 5
|
||||||
[GetSpellInfo(totemData[string_lower("Stoneclaw Totem")].id)] = totemData[string_lower("Stoneclaw Totem")].pulse,
|
[58771] = totemData[string_lower("Mana Spring Totem")].pulse, -- Rank 6
|
||||||
[5730] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 1
|
[58773] = totemData[string_lower("Mana Spring Totem")].pulse, -- Rank 7
|
||||||
[6390] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 2
|
[58774] = totemData[string_lower("Mana Spring Totem")].pulse, -- Rank 8
|
||||||
[6391] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 3
|
|
||||||
[6392] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 4
|
|
||||||
[10427] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 5
|
|
||||||
[10428] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 6
|
|
||||||
[25525] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 7
|
|
||||||
}
|
}
|
||||||
|
|
||||||
local totemNpcIdsToTotemData = {
|
local totemNpcIdsToTotemData = {
|
||||||
--fire
|
--fire
|
||||||
[2523] = totemData[string_lower("Searing Totem")],
|
|
||||||
[3902] = totemData[string_lower("Searing Totem")],
|
|
||||||
[3903] = totemData[string_lower("Searing Totem")],
|
|
||||||
[3904] = totemData[string_lower("Searing Totem")],
|
|
||||||
[7400] = totemData[string_lower("Searing Totem")],
|
|
||||||
[7402] = totemData[string_lower("Searing Totem")],
|
|
||||||
[15480] = totemData[string_lower("Searing Totem")],
|
|
||||||
[31162] = totemData[string_lower("Searing Totem")],
|
|
||||||
[31164] = totemData[string_lower("Searing Totem")],
|
|
||||||
[31165] = totemData[string_lower("Searing Totem")],
|
|
||||||
[21995] = totemData[string_lower("Searing Totem")],
|
|
||||||
[22209] = totemData[string_lower("Searing Totem")],
|
|
||||||
[22895] = totemData[string_lower("Searing Totem")],
|
|
||||||
[22896] = totemData[string_lower("Searing Totem")],
|
|
||||||
[34687] = totemData[string_lower("Searing Totem")],
|
|
||||||
[36532] = totemData[string_lower("Searing Totem")],
|
|
||||||
[43423] = totemData[string_lower("Searing Totem")],
|
|
||||||
[67380] = totemData[string_lower("Searing Totem")],
|
|
||||||
[73477] = totemData[string_lower("Searing Totem")],
|
|
||||||
[79238] = totemData[string_lower("Searing Totem")],
|
|
||||||
[22896] = totemData[string_lower("Searing Totem")],
|
|
||||||
[84519] = totemData[string_lower("Searing Totem")],
|
|
||||||
[110730] = totemData[string_lower("Searing Totem")],
|
|
||||||
[132178] = totemData[string_lower("Searing Totem")],
|
|
||||||
[9637] = totemData[string_lower("Searing Totem")],
|
|
||||||
|
|
||||||
[5950] = totemData[string_lower("Flametongue Totem")],
|
|
||||||
[6012] = totemData[string_lower("Flametongue Totem")],
|
|
||||||
[7423] = totemData[string_lower("Flametongue Totem")],
|
|
||||||
[10557] = totemData[string_lower("Flametongue Totem")],
|
|
||||||
[15485] = totemData[string_lower("Flametongue Totem")],
|
|
||||||
[31132] = totemData[string_lower("Flametongue Totem")],
|
|
||||||
[31133] = totemData[string_lower("Flametongue Totem")],
|
|
||||||
[31158] = totemData[string_lower("Flametongue Totem")],
|
|
||||||
[42605] = totemData[string_lower("Flametongue Totem")],
|
|
||||||
|
|
||||||
[5929] = totemData[string_lower("Magma Totem")],
|
|
||||||
[7464] = totemData[string_lower("Magma Totem")],
|
|
||||||
[7465] = totemData[string_lower("Magma Totem")],
|
|
||||||
[7466] = totemData[string_lower("Magma Totem")],
|
|
||||||
[15484] = totemData[string_lower("Magma Totem")],
|
|
||||||
[31166] = totemData[string_lower("Magma Totem")],
|
|
||||||
[31167] = totemData[string_lower("Magma Totem")],
|
|
||||||
[32887] = totemData[string_lower("Magma Totem")],
|
|
||||||
[42211] = totemData[string_lower("Magma Totem")],
|
|
||||||
[71335] = totemData[string_lower("Magma Totem")],
|
|
||||||
[71925] = totemData[string_lower("Magma Totem")],
|
|
||||||
[73085] = totemData[string_lower("Magma Totem")],
|
|
||||||
[73093] = totemData[string_lower("Magma Totem")],
|
|
||||||
[73268] = totemData[string_lower("Magma Totem")],
|
|
||||||
[88971] = totemData[string_lower("Magma Totem")],
|
|
||||||
[97369] = totemData[string_lower("Magma Totem")],
|
|
||||||
[98676] = totemData[string_lower("Magma Totem")],
|
|
||||||
|
|
||||||
[5879] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[6110] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[6111] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[7844] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[7845] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[14662] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[15482] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[15483] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[24320] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[32775] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[32776] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
|
|
||||||
[17539] = totemData[string_lower("Totem of Wrath")],
|
|
||||||
[22970] = totemData[string_lower("Totem of Wrath")],
|
|
||||||
[22971] = totemData[string_lower("Totem of Wrath")],
|
|
||||||
[30652] = totemData[string_lower("Totem of Wrath")],
|
|
||||||
[30653] = totemData[string_lower("Totem of Wrath")],
|
|
||||||
[30654] = totemData[string_lower("Totem of Wrath")],
|
|
||||||
|
|
||||||
[15439] = totemData[string_lower("Fire Elemental Totem")],
|
|
||||||
[40830] = totemData[string_lower("Fire Elemental Totem")],
|
|
||||||
[41337] = totemData[string_lower("Fire Elemental Totem")],
|
|
||||||
[41346] = totemData[string_lower("Fire Elemental Totem")],
|
|
||||||
[72301] = totemData[string_lower("Fire Elemental Totem")],
|
|
||||||
|
|
||||||
[5926] = totemData[string_lower("Frost Resistance Totem")],
|
|
||||||
[7412] = totemData[string_lower("Frost Resistance Totem")],
|
|
||||||
[7413] = totemData[string_lower("Frost Resistance Totem")],
|
|
||||||
[15486] = totemData[string_lower("Frost Resistance Totem")],
|
|
||||||
[31171] = totemData[string_lower("Frost Resistance Totem")],
|
|
||||||
[31172] = totemData[string_lower("Frost Resistance Totem")],
|
|
||||||
|
|
||||||
-- Water
|
-- Water
|
||||||
[5927] = totemData[string_lower("Fire Resistance Totem")],
|
|
||||||
[7424] = totemData[string_lower("Fire Resistance Totem")],
|
|
||||||
[7425] = totemData[string_lower("Fire Resistance Totem")],
|
|
||||||
[15487] = totemData[string_lower("Fire Resistance Totem")],
|
|
||||||
[31169] = totemData[string_lower("Fire Resistance Totem")],
|
|
||||||
[31170] = totemData[string_lower("Fire Resistance Totem")],
|
|
||||||
|
|
||||||
[5923] = totemData[string_lower("Poison Cleansing Totem")],
|
[5923] = totemData[string_lower("Poison Cleansing Totem")],
|
||||||
[22487] = totemData[string_lower("Poison Cleansing Totem")],
|
[22487] = totemData[string_lower("Poison Cleansing Totem")],
|
||||||
|
|
||||||
[5924] = totemData[string_lower("Disease Cleansing Totem")],
|
|
||||||
|
|
||||||
[3527] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[3906] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[3907] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[3908] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[3909] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[14664] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[15488] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[18235] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[31181] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[31182] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[31185] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[34686] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[36542] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[37810] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[38428] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[47077] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[72309] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[72457] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[73890] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[74433] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[97508] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[112567] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[120357] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[128539] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[132049] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
|
|
||||||
[10467] = totemData[string_lower("Mana Tide Totem")],
|
|
||||||
[11100] = totemData[string_lower("Mana Tide Totem")],
|
|
||||||
[11101] = totemData[string_lower("Mana Tide Totem")],
|
|
||||||
[17061] = totemData[string_lower("Mana Tide Totem")],
|
|
||||||
|
|
||||||
[3573] = totemData[string_lower("Mana Spring Totem")],
|
|
||||||
[7414] = totemData[string_lower("Mana Spring Totem")],
|
|
||||||
[7415] = totemData[string_lower("Mana Spring Totem")],
|
|
||||||
[7416] = totemData[string_lower("Mana Spring Totem")],
|
|
||||||
[15304] = totemData[string_lower("Mana Spring Totem")],
|
|
||||||
[15489] = totemData[string_lower("Mana Spring Totem")],
|
|
||||||
[31186] = totemData[string_lower("Mana Spring Totem")],
|
|
||||||
[31189] = totemData[string_lower("Mana Spring Totem")],
|
|
||||||
[31190] = totemData[string_lower("Mana Spring Totem")],
|
|
||||||
|
|
||||||
-- Earth
|
-- Earth
|
||||||
[2630] = totemData[string_lower("Earthbind Totem")],
|
|
||||||
[22486] = totemData[string_lower("Earthbind Totem")],
|
|
||||||
[40233] = totemData[string_lower("Earthbind Totem")],
|
|
||||||
[74737] = totemData[string_lower("Earthbind Totem")],
|
|
||||||
[79155] = totemData[string_lower("Earthbind Totem")],
|
|
||||||
|
|
||||||
[3579] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[3911] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[3912] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[3913] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[7398] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[7399] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[14870] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[15478] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[31120] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[31121] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[31122] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[40258] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[102402] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
|
|
||||||
[5873] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[5919] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[5920] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[7366] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[7367] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[7368] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[14663] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[15470] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[15474] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[18177] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[21994] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[31175] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[31176] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[36550] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[40267] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[41967] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
|
|
||||||
[5874] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
[5921] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
[5922] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
[7403] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
[15464] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
[15479] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
[21992] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
[30647] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
[31129] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
[40266] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
|
|
||||||
[15430] = totemData[string_lower("Earth Elemental Totem")],
|
|
||||||
[24649] = totemData[string_lower("Earth Elemental Totem")],
|
|
||||||
[39387] = totemData[string_lower("Earth Elemental Totem")],
|
|
||||||
[40247] = totemData[string_lower("Earth Elemental Totem")],
|
|
||||||
[72307] = totemData[string_lower("Earth Elemental Totem")],
|
|
||||||
|
|
||||||
[5913] = totemData[string_lower("Tremor Totem")],
|
|
||||||
[41938] = totemData[string_lower("Tremor Totem")],
|
|
||||||
[41939] = totemData[string_lower("Tremor Totem")],
|
|
||||||
|
|
||||||
-- Air
|
-- Air
|
||||||
[5925] = totemData[string_lower("Grounding Totem")],
|
|
||||||
[128537] = totemData[string_lower("Grounding Totem")],
|
|
||||||
[136251] = totemData[string_lower("Grounding Totem")],
|
|
||||||
|
|
||||||
[7486] = totemData[string_lower("Grace of Air Totem")],
|
[7486] = totemData[string_lower("Grace of Air Totem")],
|
||||||
[7487] = totemData[string_lower("Grace of Air Totem")],
|
[7487] = totemData[string_lower("Grace of Air Totem")],
|
||||||
[15463] = totemData[string_lower("Grace of Air Totem")],
|
[15463] = totemData[string_lower("Grace of Air Totem")],
|
||||||
|
|
||||||
[7467] = totemData[string_lower("Nature Resistance Totem")],
|
|
||||||
[7468] = totemData[string_lower("Nature Resistance Totem")],
|
|
||||||
[7469] = totemData[string_lower("Nature Resistance Totem")],
|
|
||||||
[15490] = totemData[string_lower("Nature Resistance Totem")],
|
|
||||||
[31173] = totemData[string_lower("Nature Resistance Totem")],
|
|
||||||
[31174] = totemData[string_lower("Nature Resistance Totem")],
|
|
||||||
|
|
||||||
[6112] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[7483] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[7484] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[14666] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[15496] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[15497] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[22897] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[41940] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[41941] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[80703] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[105690] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[133684] = totemData[string_lower("Windfury Totem")],
|
|
||||||
|
|
||||||
[3968] = totemData[string_lower("Sentry Totem")],
|
|
||||||
[28938] = totemData[string_lower("Sentry Totem")],
|
|
||||||
[40187] = totemData[string_lower("Sentry Totem")],
|
|
||||||
[69505] = totemData[string_lower("Sentry Totem")],
|
|
||||||
[70413] = totemData[string_lower("Sentry Totem")],
|
|
||||||
[71145] = totemData[string_lower("Sentry Totem")],
|
|
||||||
[147410] = totemData[string_lower("Sentry Totem")],
|
|
||||||
|
|
||||||
[9687] = totemData[string_lower("Windwall Totem")],
|
[9687] = totemData[string_lower("Windwall Totem")],
|
||||||
[9688] = totemData[string_lower("Windwall Totem")],
|
[9688] = totemData[string_lower("Windwall Totem")],
|
||||||
[9689] = totemData[string_lower("Windwall Totem")],
|
[9689] = totemData[string_lower("Windwall Totem")],
|
||||||
[15492] = totemData[string_lower("Windwall Totem")],
|
[15492] = totemData[string_lower("Windwall Totem")],
|
||||||
|
|
||||||
[15447] = totemData[string_lower("Wrath of Air Totem")],
|
|
||||||
[36556] = totemData[string_lower("Wrath of Air Totem")],
|
|
||||||
|
|
||||||
[15803] = totemData[string_lower("Tranquil Air Totem")],
|
[15803] = totemData[string_lower("Tranquil Air Totem")],
|
||||||
}
|
}
|
||||||
|
|
||||||
|
local totemDataShared, totemNpcIdsToTotemDataShared, totemSpellIdToPulseShared = Gladdy:GetSharedTotemData()
|
||||||
|
Gladdy:AddEntriesToTable(totemData, totemDataShared)
|
||||||
|
Gladdy:AddEntriesToTable(totemNpcIdsToTotemData, totemNpcIdsToTotemDataShared)
|
||||||
|
Gladdy:AddEntriesToTable(totemSpellIdToPulse, totemSpellIdToPulseShared)
|
||||||
|
|
||||||
function Gladdy:GetTotemData()
|
function Gladdy:GetTotemData()
|
||||||
return totemData, totemNpcIdsToTotemData, totemSpellIdToPulse
|
return totemData, totemNpcIdsToTotemData, totemSpellIdToPulse
|
||||||
end
|
end
|
||||||
|
@ -85,14 +85,17 @@ local specBuffs = {
|
|||||||
-- HUNTER
|
-- HUNTER
|
||||||
[GetSpellInfo(20895)] = L["Beast Mastery"], -- Spirit Bond
|
[GetSpellInfo(20895)] = L["Beast Mastery"], -- Spirit Bond
|
||||||
[GetSpellInfo(34471)] = L["Beast Mastery"], -- The Beast Within
|
[GetSpellInfo(34471)] = L["Beast Mastery"], -- The Beast Within
|
||||||
|
[GetSpellInfo(75447)] = L["Beast Mastery"], -- Ferocious Inspiration
|
||||||
[GetSpellInfo(19506)] = L["Marksmanship"], -- Trueshot Aura
|
[GetSpellInfo(19506)] = L["Marksmanship"], -- Trueshot Aura
|
||||||
[GetSpellInfo(64420)] = L["Survival"], -- Sniper Training
|
[GetSpellInfo(64420)] = L["Survival"], -- Sniper Training
|
||||||
-- DRUID
|
-- DRUID
|
||||||
[GetSpellInfo(24932)] = L["Feral"], -- Leader of the Pack
|
[GetSpellInfo(24932)] = L["Feral"], -- Leader of the Pack
|
||||||
[GetSpellInfo(16975)] = L["Feral"], -- Predatory Strikes
|
[GetSpellInfo(16975)] = L["Feral"], -- Predatory Strikes
|
||||||
[GetSpellInfo(50334)] = L["Feral"], -- Berserk
|
[GetSpellInfo(50334) .. " Feral"] = L["Feral"], -- Berserk
|
||||||
[GetSpellInfo(24907)] = L["Balance"], -- Moonkin Aura
|
[GetSpellInfo(24907)] = L["Balance"], -- Moonkin Aura
|
||||||
[GetSpellInfo(24858)] = L["Balance"], -- Moonkin Form
|
[GetSpellInfo(24858)] = L["Balance"], -- Moonkin Form
|
||||||
|
[GetSpellInfo(48504)] = L["Restoration"], -- Living Seed
|
||||||
|
[GetSpellInfo(45283)] = L["Restoration"], -- Natural Perfection
|
||||||
[GetSpellInfo(53251)] = L["Restoration"], -- Wild Growth
|
[GetSpellInfo(53251)] = L["Restoration"], -- Wild Growth
|
||||||
[GetSpellInfo(16188)] = L["Restoration"], -- Nature's Swiftness
|
[GetSpellInfo(16188)] = L["Restoration"], -- Nature's Swiftness
|
||||||
[GetSpellInfo(33891)] = L["Restoration"], -- Tree of Life
|
[GetSpellInfo(33891)] = L["Restoration"], -- Tree of Life
|
||||||
@ -150,6 +153,7 @@ local specSpells = {
|
|||||||
[GetSpellInfo(47843)] = L["Affliction"], -- Unstable Affliction
|
[GetSpellInfo(47843)] = L["Affliction"], -- Unstable Affliction
|
||||||
[GetSpellInfo(59672)] = L["Demonology"], -- Metamorphosis
|
[GetSpellInfo(59672)] = L["Demonology"], -- Metamorphosis
|
||||||
[GetSpellInfo(47193)] = L["Demonology"], -- Demonic Empowerment
|
[GetSpellInfo(47193)] = L["Demonology"], -- Demonic Empowerment
|
||||||
|
[GetSpellInfo(47996) .. " Felguard"] = L["Demonology"], -- Intercept Felguard
|
||||||
[GetSpellInfo(59172)] = L["Destruction"], -- Chaos Bolt
|
[GetSpellInfo(59172)] = L["Destruction"], -- Chaos Bolt
|
||||||
[GetSpellInfo(47847)] = L["Destruction"], -- Shadowfury
|
[GetSpellInfo(47847)] = L["Destruction"], -- Shadowfury
|
||||||
-- SHAMAN
|
-- SHAMAN
|
||||||
@ -172,7 +176,7 @@ local specSpells = {
|
|||||||
[GetSpellInfo(24858)] = L["Balance"], -- Moonkin Form
|
[GetSpellInfo(24858)] = L["Balance"], -- Moonkin Form
|
||||||
[GetSpellInfo(48566)] = L["Feral"], -- Mangle (Cat)
|
[GetSpellInfo(48566)] = L["Feral"], -- Mangle (Cat)
|
||||||
[GetSpellInfo(48564)] = L["Feral"], -- Mangle (Bear)
|
[GetSpellInfo(48564)] = L["Feral"], -- Mangle (Bear)
|
||||||
[GetSpellInfo(50334)] = L["Feral"], -- Berserk
|
[GetSpellInfo(50334) .. " Feral"] = L["Feral"], -- Berserk
|
||||||
[GetSpellInfo(18562)] = L["Restoration"], -- Swiftmend
|
[GetSpellInfo(18562)] = L["Restoration"], -- Swiftmend
|
||||||
[GetSpellInfo(17116)] = L["Restoration"], -- Nature's Swiftness
|
[GetSpellInfo(17116)] = L["Restoration"], -- Nature's Swiftness
|
||||||
[GetSpellInfo(33891)] = L["Restoration"], -- Tree of Life
|
[GetSpellInfo(33891)] = L["Restoration"], -- Tree of Life
|
||||||
@ -486,7 +490,7 @@ local importantAuras = {
|
|||||||
priority = 20,
|
priority = 20,
|
||||||
spellID = 63529,
|
spellID = 63529,
|
||||||
},
|
},
|
||||||
["Unstable Affliction Silence"] = { -- Unstable Affliction Silence (GetSpellInfo returns "Unstable Affliction")
|
[select(1, GetSpellInfo(31117)) .. " Silence"] = { -- Unstable Affliction Silence (GetSpellInfo returns "Unstable Affliction")
|
||||||
track = AURA_TYPE_DEBUFF,
|
track = AURA_TYPE_DEBUFF,
|
||||||
altName = select(1, GetSpellInfo(31117)) .. " Silence",
|
altName = select(1, GetSpellInfo(31117)) .. " Silence",
|
||||||
priority = 20,
|
priority = 20,
|
||||||
@ -583,7 +587,7 @@ local importantAuras = {
|
|||||||
},
|
},
|
||||||
[GetSpellInfo(54428)] = { -- Divine Plea
|
[GetSpellInfo(54428)] = { -- Divine Plea
|
||||||
track = AURA_TYPE_BUFF,
|
track = AURA_TYPE_BUFF,
|
||||||
priority = 20,
|
priority = 15,
|
||||||
spellID = 54428,
|
spellID = 54428,
|
||||||
},
|
},
|
||||||
[GetSpellInfo(31821)] = { -- Aura mastery
|
[GetSpellInfo(31821)] = { -- Aura mastery
|
||||||
@ -611,11 +615,16 @@ local importantAuras = {
|
|||||||
priority = 9,
|
priority = 9,
|
||||||
spellID = 6346,
|
spellID = 6346,
|
||||||
},
|
},
|
||||||
[GetSpellInfo(50334)] = {-- Berserk
|
[GetSpellInfo(50334) .. " Feral"] = {-- Berserk
|
||||||
track = AURA_TYPE_BUFF,
|
track = AURA_TYPE_BUFF,
|
||||||
priority = 20,
|
priority = 20,
|
||||||
spellID = 50334,
|
spellID = 50334,
|
||||||
},
|
},
|
||||||
|
[GetSpellInfo(46924)] = { -- Bladestorm
|
||||||
|
track = AURA_TYPE_BUFF,
|
||||||
|
priority = 20,
|
||||||
|
spellID = 46924,
|
||||||
|
},
|
||||||
|
|
||||||
--- Turtling abilities
|
--- Turtling abilities
|
||||||
[GetSpellInfo(871)] = { -- Shield Wall
|
[GetSpellInfo(871)] = { -- Shield Wall
|
||||||
@ -675,12 +684,22 @@ local importantAuras = {
|
|||||||
priority = 30,
|
priority = 30,
|
||||||
spellID = 1719,
|
spellID = 1719,
|
||||||
},
|
},
|
||||||
|
[GetSpellInfo(48792)] = { -- Icebound Fortitude
|
||||||
|
track = AURA_TYPE_BUFF,
|
||||||
|
priority = 15,
|
||||||
|
spellID = 48792,
|
||||||
|
},
|
||||||
|
[GetSpellInfo(49039)] = { -- Lichborne
|
||||||
|
track = AURA_TYPE_BUFF,
|
||||||
|
priority = 15,
|
||||||
|
spellID = 49039,
|
||||||
|
},
|
||||||
|
|
||||||
--- Alt Stuff
|
--- Alt Stuff
|
||||||
[GetSpellInfo(34709)] = { -- Shadowsight Buff
|
[GetSpellInfo(34709)] = { -- Shadowsight Buff
|
||||||
track = AURA_TYPE_BUFF,
|
track = AURA_TYPE_DEBUFF,
|
||||||
duration = 15,
|
duration = 15,
|
||||||
priority = 15,
|
priority = 9,
|
||||||
magic = true,
|
magic = true,
|
||||||
spellID = 34709,
|
spellID = 34709,
|
||||||
},
|
},
|
||||||
@ -784,10 +803,11 @@ local cooldownList = {
|
|||||||
[8983] = 60, -- Bash
|
[8983] = 60, -- Bash
|
||||||
[53312] = 60, -- Natures Grasp
|
[53312] = 60, -- Natures Grasp
|
||||||
[48505] = { cd = 90, spec = L["Balance"], }, -- Starfall
|
[48505] = { cd = 90, spec = L["Balance"], }, -- Starfall
|
||||||
[50334] = { cd = 180, spec = L["Feral"], }, -- Berserk
|
[50334] = { cd = 180, spec = L["Feral"], altName = GetSpellInfo(50334) .. " Feral" }, -- Berserk
|
||||||
[17116] = { cd = 120, spec = L["Restoration"], }, -- Natures Swiftness
|
[17116] = { cd = 120, spec = L["Restoration"], }, -- Natures Swiftness
|
||||||
[18562] = { cd = 15, spec = L["Restoration"], }, -- Swiftmend
|
[18562] = { cd = 15, spec = L["Restoration"], }, -- Swiftmend
|
||||||
[33831] = { cd = 180, spec = L["Balance"], }, -- Force of Nature
|
[33831] = { cd = 180, spec = L["Balance"], }, -- Force of Nature
|
||||||
|
[61384] = { cd = 20, spec = L["Balance"], }, -- Typhoon
|
||||||
},
|
},
|
||||||
|
|
||||||
-- Shaman
|
-- Shaman
|
||||||
@ -845,7 +865,7 @@ local cooldownList = {
|
|||||||
[17962] = { cd = 10, spec = L["Destruction"], }, -- Conflagrate
|
[17962] = { cd = 10, spec = L["Destruction"], }, -- Conflagrate
|
||||||
[59172] = { cd = 12, spec = L["Destruction"], }, -- Chaos Bolt
|
[59172] = { cd = 12, spec = L["Destruction"], }, -- Chaos Bolt
|
||||||
[47241] = { cd = 180, spec = L["Demonology"], }, -- Metamorphosis
|
[47241] = { cd = 180, spec = L["Demonology"], }, -- Metamorphosis
|
||||||
[47996] = { cd = 30, spec = L["Demonology"], pet = true, }, -- Intercept
|
[47996] = { cd = 30, spec = L["Demonology"], pet = true, altName = GetSpellInfo(47996) .. " Felguard" }, -- Intercept
|
||||||
[1122] = { cd = 600, spec = L["Demonology"], }, -- Inferno
|
[1122] = { cd = 600, spec = L["Demonology"], }, -- Inferno
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -889,7 +909,7 @@ local cooldownList = {
|
|||||||
[19503] = 30, -- Scatter Shot
|
[19503] = 30, -- Scatter Shot
|
||||||
[19263] = 90, -- Deterrence
|
[19263] = 90, -- Deterrence
|
||||||
[781] = 15, -- Disengage
|
[781] = 15, -- Disengage
|
||||||
[5384] = 20, -- Feign Death
|
[5384] = 30, -- Feign Death
|
||||||
[3045] = 20, -- Rapid Fire
|
[3045] = 20, -- Rapid Fire
|
||||||
[60192] = { cd = 28, -- Freezing Arrow
|
[60192] = { cd = 28, -- Freezing Arrow
|
||||||
sharedCD = {
|
sharedCD = {
|
||||||
@ -1067,211 +1087,21 @@ end
|
|||||||
|
|
||||||
local totemData = {
|
local totemData = {
|
||||||
-- Fire
|
-- Fire
|
||||||
[string_lower("Searing Totem")] = { id = 3599, texture = select(3, GetSpellInfo(3599)), color = { r = 0, g = 0, b = 0, a = 1 } },
|
|
||||||
[string_lower("Flametongue Totem")] = { id = 8227, texture = select(3, GetSpellInfo(8227)), color = { r = 0, g = 0, b = 0, a = 1 } },
|
|
||||||
[string_lower("Magma Totem")] = { id = 8190, texture = select(3, GetSpellInfo(8190)), color = { r = 0, g = 0, b = 0, a = 1 }, pulse = 2 },
|
|
||||||
[string_lower("Fire Nova Totem")] = { id = 1535, texture = select(3, GetSpellInfo(1535)), color = { r = 0, g = 0, b = 0, a = 1 }, pulse = { cd = 4, once = true } },
|
|
||||||
[string_lower("Totem of Wrath")] = { id = 30706, texture = select(3, GetSpellInfo(30706)), color = { r = 0, g = 0, b = 0, a = 1 } },
|
|
||||||
[string_lower("Fire Elemental Totem")] = { id = 32982, texture = select(3, GetSpellInfo(32982)), color = { r = 0, g = 0, b = 0, a = 1 } },
|
|
||||||
[string_lower("Frost Resistance Totem")] = { id = 8181, texture = select(3, GetSpellInfo(8181)), color = { r = 0, g = 0, b = 0, a = 1 } },
|
|
||||||
[string_lower("Totem of Wrath")] = { id = 30706, texture = select(3, GetSpellInfo(30706)), color = { r = 0, g = 0, b = 0, a = 1 } },
|
|
||||||
-- Water
|
-- Water
|
||||||
[string_lower("Fire Resistance Totem")] = { id = 8184, texture = select(3, GetSpellInfo(8184)), color = { r = 0, g = 0, b = 0, a = 1 } },
|
[string_lower("Disease Cleansing Totem")] = {id = 8170,texture = select(3, GetSpellInfo(8170)), color = {r = 0, g = 0, b = 0, a = 1}, pulse = 3},
|
||||||
[string_lower("Disease Cleansing Totem")] = { id = 8170, texture = select(3, GetSpellInfo(8170)), color = { r = 0, g = 0, b = 0, a = 1 }, pulse = 5 },
|
[string_lower("Mana Spring Totem")] = { id = 5675, texture = select(3, GetSpellInfo(5675)), color = { r = 0, g = 0, b = 0, a = 1 } },
|
||||||
[string_lower("Healing Stream Totem")] = { id = 5394, texture = select(3, GetSpellInfo(5394)), color = { r = 0, g = 0, b = 0, a = 1 }, pulse = 2 },
|
|
||||||
[string_lower("Mana Tide Totem")] = { id = 16190, texture = select(3, GetSpellInfo(16190)), color = { r = 0.078, g = 0.9, b = 0.16, a = 1 } },
|
|
||||||
[string_lower("Mana Spring Totem")] = { id = 5675, texture = select(3, GetSpellInfo(5675)), color = { r = 0, g = 0, b = 0, a = 1 }, pulse = 2 },
|
|
||||||
-- Earth
|
-- Earth
|
||||||
[string_lower("Earthbind Totem")] = { id = 2484, texture = select(3, GetSpellInfo(2484)), color = { r = 0.5, g = 0.5, b = 0.5, a = 1 }, pulse = 3 },
|
|
||||||
[string_lower("Stoneclaw Totem")] = { id = 5730, texture = select(3, GetSpellInfo(5730)), color = { r = 0, g = 0, b = 0, a = 1 }, pulse = 2 },
|
|
||||||
[string_lower("Stoneskin Totem")] = { id = 8071, texture = select(3, GetSpellInfo(8071)), color = { r = 0, g = 0, b = 0, a = 1 } },
|
|
||||||
[string_lower("Strength of Earth Totem")] = { id = 8075, texture = select(3, GetSpellInfo(8075)), color = { r = 0, g = 0, b = 0, a = 1 } },
|
|
||||||
[string_lower("Earth Elemental Totem")] = { id = 33663, texture = select(3, GetSpellInfo(33663)), color = { r = 0, g = 0, b = 0, a = 1 } },
|
|
||||||
[string_lower("Tremor Totem")] = { id = 8143, texture = select(3, GetSpellInfo(8143)), color = { r = 1, g = 0.9, b = 0.1, a = 1 }, pulse = 3 },
|
|
||||||
-- Air
|
-- Air
|
||||||
[string_lower("Grounding Totem")] = { id = 8177, texture = select(3, GetSpellInfo(8177)), color = { r = 0, g = 0.53, b = 0.92, a = 1 } },
|
|
||||||
[string_lower("Nature Resistance Totem")] = { id = 10595, texture = select(3, GetSpellInfo(10595)), color = { r = 0, g = 0, b = 0, a = 1 } },
|
|
||||||
[string_lower("Windfury Totem")] = { id = 8512, texture = select(3, GetSpellInfo(8512)), color = { r = 0.96, g = 0, b = 0.07, a = 1 } },
|
|
||||||
[string_lower("Sentry Totem")] = { id = 6495, texture = select(3, GetSpellInfo(6495)), color = { r = 0, g = 0, b = 0, a = 1 } },
|
|
||||||
[string_lower("Wrath of Air Totem")] = { id = 3738, texture = select(3, GetSpellInfo(3738)), color = { r = 0, g = 0, b = 0, a = 1 } },
|
|
||||||
}
|
}
|
||||||
|
|
||||||
local totemSpellIdToPulse = {
|
local totemSpellIdToPulse = {
|
||||||
[GetSpellInfo(totemData[string_lower("Earthbind Totem")].id)] = totemData[string_lower("Earthbind Totem")].pulse,
|
|
||||||
[2484] = totemData[string_lower("Earthbind Totem")].pulse,
|
|
||||||
[GetSpellInfo(totemData[string_lower("Tremor Totem")].id)] = totemData[string_lower("Tremor Totem")].pulse,
|
|
||||||
[8143] = totemData[string_lower("Tremor Totem")].pulse,
|
|
||||||
--[GetSpellInfo(totemData[string_lower("Poison Cleansing Totem")].id)] = totemData[string_lower("Poison Cleansing Totem")].pulse,
|
|
||||||
--[8166] = totemData[string_lower("Poison Cleansing Totem")].pulse,
|
|
||||||
[GetSpellInfo(totemData[string_lower("Disease Cleansing Totem")].id)] = totemData[string_lower("Disease Cleansing Totem")].pulse,
|
[GetSpellInfo(totemData[string_lower("Disease Cleansing Totem")].id)] = totemData[string_lower("Disease Cleansing Totem")].pulse,
|
||||||
[8170] = totemData[string_lower("Disease Cleansing Totem")].pulse,
|
[8170] = totemData[string_lower("Disease Cleansing Totem")].pulse,
|
||||||
[GetSpellInfo(totemData[string_lower("Fire Nova Totem")].id)] = totemData[string_lower("Fire Nova Totem")].pulse,
|
|
||||||
[1535] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 1
|
|
||||||
[8498] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 2
|
|
||||||
[8499] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 3
|
|
||||||
[11314] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 4
|
|
||||||
[11315] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 5
|
|
||||||
[25546] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 6
|
|
||||||
[25547] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 7
|
|
||||||
[GetSpellInfo(totemData[string_lower("Magma Totem")].id)] = totemData[string_lower("Magma Totem")].pulse,
|
|
||||||
[8190] = totemData[string_lower("Magma Totem")].pulse, -- Rank 1
|
|
||||||
[10585] = totemData[string_lower("Magma Totem")].pulse, -- Rank 2
|
|
||||||
[10586] = totemData[string_lower("Magma Totem")].pulse, -- Rank 3
|
|
||||||
[10587] = totemData[string_lower("Magma Totem")].pulse, -- Rank 4
|
|
||||||
[25552] = totemData[string_lower("Magma Totem")].pulse, -- Rank 5
|
|
||||||
[GetSpellInfo(totemData[string_lower("Healing Stream Totem")].id)] = totemData[string_lower("Healing Stream Totem")].pulse,
|
|
||||||
[5394] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 1
|
|
||||||
[6375] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 2
|
|
||||||
[6377] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 3
|
|
||||||
[10462] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 4
|
|
||||||
[10463] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 5
|
|
||||||
[25567] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 6
|
|
||||||
[GetSpellInfo(totemData[string_lower("Mana Spring Totem")].id)] = totemData[string_lower("Mana Spring Totem")].pulse,
|
|
||||||
[5675] = totemData[string_lower("Mana Spring Totem")].pulse, -- Rank 1
|
|
||||||
[10495] = totemData[string_lower("Mana Spring Totem")].pulse, -- Rank 2
|
|
||||||
[10496] = totemData[string_lower("Mana Spring Totem")].pulse, -- Rank 3
|
|
||||||
[10497] = totemData[string_lower("Mana Spring Totem")].pulse, -- Rank 4
|
|
||||||
[25570] = totemData[string_lower("Mana Spring Totem")].pulse, -- Rank 5
|
|
||||||
[GetSpellInfo(totemData[string_lower("Stoneclaw Totem")].id)] = totemData[string_lower("Stoneclaw Totem")].pulse,
|
|
||||||
[5730] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 1
|
|
||||||
[6390] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 2
|
|
||||||
[6391] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 3
|
|
||||||
[6392] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 4
|
|
||||||
[10427] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 5
|
|
||||||
[10428] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 6
|
|
||||||
[25525] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 7
|
|
||||||
}
|
}
|
||||||
|
|
||||||
local totemNpcIdsToTotemData = {
|
local totemNpcIdsToTotemData = {
|
||||||
--fire
|
|
||||||
[2523] = totemData[string_lower("Searing Totem")],
|
|
||||||
[3902] = totemData[string_lower("Searing Totem")],
|
|
||||||
[3903] = totemData[string_lower("Searing Totem")],
|
|
||||||
[3904] = totemData[string_lower("Searing Totem")],
|
|
||||||
[7400] = totemData[string_lower("Searing Totem")],
|
|
||||||
[7402] = totemData[string_lower("Searing Totem")],
|
|
||||||
[15480] = totemData[string_lower("Searing Totem")],
|
|
||||||
[31162] = totemData[string_lower("Searing Totem")],
|
|
||||||
[31164] = totemData[string_lower("Searing Totem")],
|
|
||||||
[31165] = totemData[string_lower("Searing Totem")],
|
|
||||||
[21995] = totemData[string_lower("Searing Totem")],
|
|
||||||
[22209] = totemData[string_lower("Searing Totem")],
|
|
||||||
[22895] = totemData[string_lower("Searing Totem")],
|
|
||||||
[22896] = totemData[string_lower("Searing Totem")],
|
|
||||||
[34687] = totemData[string_lower("Searing Totem")],
|
|
||||||
[36532] = totemData[string_lower("Searing Totem")],
|
|
||||||
[43423] = totemData[string_lower("Searing Totem")],
|
|
||||||
[67380] = totemData[string_lower("Searing Totem")],
|
|
||||||
[73477] = totemData[string_lower("Searing Totem")],
|
|
||||||
[79238] = totemData[string_lower("Searing Totem")],
|
|
||||||
[22896] = totemData[string_lower("Searing Totem")],
|
|
||||||
[84519] = totemData[string_lower("Searing Totem")],
|
|
||||||
[110730] = totemData[string_lower("Searing Totem")],
|
|
||||||
[132178] = totemData[string_lower("Searing Totem")],
|
|
||||||
[9637] = totemData[string_lower("Searing Totem")],
|
|
||||||
|
|
||||||
[5950] = totemData[string_lower("Flametongue Totem")],
|
|
||||||
[6012] = totemData[string_lower("Flametongue Totem")],
|
|
||||||
[7423] = totemData[string_lower("Flametongue Totem")],
|
|
||||||
[10557] = totemData[string_lower("Flametongue Totem")],
|
|
||||||
[15485] = totemData[string_lower("Flametongue Totem")],
|
|
||||||
[31132] = totemData[string_lower("Flametongue Totem")],
|
|
||||||
[31133] = totemData[string_lower("Flametongue Totem")],
|
|
||||||
[31158] = totemData[string_lower("Flametongue Totem")],
|
|
||||||
[42605] = totemData[string_lower("Flametongue Totem")],
|
|
||||||
|
|
||||||
[5929] = totemData[string_lower("Magma Totem")],
|
|
||||||
[7464] = totemData[string_lower("Magma Totem")],
|
|
||||||
[7465] = totemData[string_lower("Magma Totem")],
|
|
||||||
[7466] = totemData[string_lower("Magma Totem")],
|
|
||||||
[15484] = totemData[string_lower("Magma Totem")],
|
|
||||||
[31166] = totemData[string_lower("Magma Totem")],
|
|
||||||
[31167] = totemData[string_lower("Magma Totem")],
|
|
||||||
[32887] = totemData[string_lower("Magma Totem")],
|
|
||||||
[42211] = totemData[string_lower("Magma Totem")],
|
|
||||||
[71335] = totemData[string_lower("Magma Totem")],
|
|
||||||
[71925] = totemData[string_lower("Magma Totem")],
|
|
||||||
[73085] = totemData[string_lower("Magma Totem")],
|
|
||||||
[73093] = totemData[string_lower("Magma Totem")],
|
|
||||||
[73268] = totemData[string_lower("Magma Totem")],
|
|
||||||
[88971] = totemData[string_lower("Magma Totem")],
|
|
||||||
[97369] = totemData[string_lower("Magma Totem")],
|
|
||||||
[98676] = totemData[string_lower("Magma Totem")],
|
|
||||||
|
|
||||||
[5879] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[6110] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[6111] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[7844] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[7845] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[14662] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[15482] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[15483] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[24320] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[32775] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
[32776] = totemData[string_lower("Fire Nova Totem")],
|
|
||||||
|
|
||||||
[17539] = totemData[string_lower("Totem of Wrath")],
|
|
||||||
[22970] = totemData[string_lower("Totem of Wrath")],
|
|
||||||
[22971] = totemData[string_lower("Totem of Wrath")],
|
|
||||||
[30652] = totemData[string_lower("Totem of Wrath")],
|
|
||||||
[30653] = totemData[string_lower("Totem of Wrath")],
|
|
||||||
[30654] = totemData[string_lower("Totem of Wrath")],
|
|
||||||
|
|
||||||
[15439] = totemData[string_lower("Fire Elemental Totem")],
|
|
||||||
[40830] = totemData[string_lower("Fire Elemental Totem")],
|
|
||||||
[41337] = totemData[string_lower("Fire Elemental Totem")],
|
|
||||||
[41346] = totemData[string_lower("Fire Elemental Totem")],
|
|
||||||
[72301] = totemData[string_lower("Fire Elemental Totem")],
|
|
||||||
|
|
||||||
[5926] = totemData[string_lower("Frost Resistance Totem")],
|
|
||||||
[7412] = totemData[string_lower("Frost Resistance Totem")],
|
|
||||||
[7413] = totemData[string_lower("Frost Resistance Totem")],
|
|
||||||
[15486] = totemData[string_lower("Frost Resistance Totem")],
|
|
||||||
[31171] = totemData[string_lower("Frost Resistance Totem")],
|
|
||||||
[31172] = totemData[string_lower("Frost Resistance Totem")],
|
|
||||||
|
|
||||||
-- Water
|
|
||||||
[5927] = totemData[string_lower("Fire Resistance Totem")],
|
|
||||||
[7424] = totemData[string_lower("Fire Resistance Totem")],
|
|
||||||
[7425] = totemData[string_lower("Fire Resistance Totem")],
|
|
||||||
[15487] = totemData[string_lower("Fire Resistance Totem")],
|
|
||||||
[31169] = totemData[string_lower("Fire Resistance Totem")],
|
|
||||||
[31170] = totemData[string_lower("Fire Resistance Totem")],
|
|
||||||
|
|
||||||
|
|
||||||
[5924] = totemData[string_lower("Disease Cleansing Totem")],
|
[5924] = totemData[string_lower("Disease Cleansing Totem")],
|
||||||
|
|
||||||
[3527] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[3906] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[3907] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[3908] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[3909] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[14664] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[15488] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[18235] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[31181] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[31182] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[31185] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[34686] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[36542] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[37810] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[38428] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[47077] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[72309] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[72457] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[73890] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[74433] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[97508] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[112567] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[120357] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[128539] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
[132049] = totemData[string_lower("Healing Stream Totem")],
|
|
||||||
|
|
||||||
[10467] = totemData[string_lower("Mana Tide Totem")],
|
|
||||||
[11100] = totemData[string_lower("Mana Tide Totem")],
|
|
||||||
[11101] = totemData[string_lower("Mana Tide Totem")],
|
|
||||||
[17061] = totemData[string_lower("Mana Tide Totem")],
|
|
||||||
|
|
||||||
[3573] = totemData[string_lower("Mana Spring Totem")],
|
[3573] = totemData[string_lower("Mana Spring Totem")],
|
||||||
[7414] = totemData[string_lower("Mana Spring Totem")],
|
[7414] = totemData[string_lower("Mana Spring Totem")],
|
||||||
[7415] = totemData[string_lower("Mana Spring Totem")],
|
[7415] = totemData[string_lower("Mana Spring Totem")],
|
||||||
@ -1282,102 +1112,14 @@ local totemNpcIdsToTotemData = {
|
|||||||
[31189] = totemData[string_lower("Mana Spring Totem")],
|
[31189] = totemData[string_lower("Mana Spring Totem")],
|
||||||
[31190] = totemData[string_lower("Mana Spring Totem")],
|
[31190] = totemData[string_lower("Mana Spring Totem")],
|
||||||
|
|
||||||
-- Earth
|
|
||||||
[2630] = totemData[string_lower("Earthbind Totem")],
|
|
||||||
[22486] = totemData[string_lower("Earthbind Totem")],
|
|
||||||
[40233] = totemData[string_lower("Earthbind Totem")],
|
|
||||||
[74737] = totemData[string_lower("Earthbind Totem")],
|
|
||||||
[79155] = totemData[string_lower("Earthbind Totem")],
|
|
||||||
|
|
||||||
[3579] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[3911] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[3912] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[3913] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[7398] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[7399] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[14870] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[15478] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[31120] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[31121] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[31122] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[40258] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
[102402] = totemData[string_lower("Stoneclaw Totem")],
|
|
||||||
|
|
||||||
[5873] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[5919] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[5920] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[7366] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[7367] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[7368] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[14663] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[15470] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[15474] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[18177] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[21994] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[31175] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[31176] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[36550] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[40267] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
[41967] = totemData[string_lower("Stoneskin Totem")],
|
|
||||||
|
|
||||||
[5874] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
[5921] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
[5922] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
[7403] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
[15464] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
[15479] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
[21992] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
[30647] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
[31129] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
[40266] = totemData[string_lower("Strength of Earth Totem")],
|
|
||||||
|
|
||||||
[15430] = totemData[string_lower("Earth Elemental Totem")],
|
|
||||||
[24649] = totemData[string_lower("Earth Elemental Totem")],
|
|
||||||
[39387] = totemData[string_lower("Earth Elemental Totem")],
|
|
||||||
[40247] = totemData[string_lower("Earth Elemental Totem")],
|
|
||||||
[72307] = totemData[string_lower("Earth Elemental Totem")],
|
|
||||||
|
|
||||||
[5913] = totemData[string_lower("Tremor Totem")],
|
|
||||||
[41938] = totemData[string_lower("Tremor Totem")],
|
|
||||||
[41939] = totemData[string_lower("Tremor Totem")],
|
|
||||||
|
|
||||||
-- Air
|
|
||||||
[5925] = totemData[string_lower("Grounding Totem")],
|
|
||||||
[128537] = totemData[string_lower("Grounding Totem")],
|
|
||||||
[136251] = totemData[string_lower("Grounding Totem")],
|
|
||||||
|
|
||||||
[7467] = totemData[string_lower("Nature Resistance Totem")],
|
|
||||||
[7468] = totemData[string_lower("Nature Resistance Totem")],
|
|
||||||
[7469] = totemData[string_lower("Nature Resistance Totem")],
|
|
||||||
[15490] = totemData[string_lower("Nature Resistance Totem")],
|
|
||||||
[31173] = totemData[string_lower("Nature Resistance Totem")],
|
|
||||||
[31174] = totemData[string_lower("Nature Resistance Totem")],
|
|
||||||
|
|
||||||
[6112] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[7483] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[7484] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[14666] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[15496] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[15497] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[22897] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[41940] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[41941] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[80703] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[105690] = totemData[string_lower("Windfury Totem")],
|
|
||||||
[133684] = totemData[string_lower("Windfury Totem")],
|
|
||||||
|
|
||||||
[3968] = totemData[string_lower("Sentry Totem")],
|
|
||||||
[28938] = totemData[string_lower("Sentry Totem")],
|
|
||||||
[40187] = totemData[string_lower("Sentry Totem")],
|
|
||||||
[69505] = totemData[string_lower("Sentry Totem")],
|
|
||||||
[70413] = totemData[string_lower("Sentry Totem")],
|
|
||||||
[71145] = totemData[string_lower("Sentry Totem")],
|
|
||||||
[147410] = totemData[string_lower("Sentry Totem")],
|
|
||||||
|
|
||||||
[15447] = totemData[string_lower("Wrath of Air Totem")],
|
|
||||||
[36556] = totemData[string_lower("Wrath of Air Totem")],
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
local totemDataShared, totemNpcIdsToTotemDataShared, totemSpellIdToPulseShared = Gladdy:GetSharedTotemData()
|
||||||
|
Gladdy:AddEntriesToTable(totemData, totemDataShared)
|
||||||
|
Gladdy:AddEntriesToTable(totemNpcIdsToTotemData, totemNpcIdsToTotemDataShared)
|
||||||
|
Gladdy:AddEntriesToTable(totemSpellIdToPulse, totemSpellIdToPulseShared)
|
||||||
|
|
||||||
function Gladdy:GetTotemData()
|
function Gladdy:GetTotemData()
|
||||||
return totemData, totemNpcIdsToTotemData, totemSpellIdToPulse
|
return totemData, totemNpcIdsToTotemData, totemSpellIdToPulse
|
||||||
end
|
end
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
local tbl_sort, select, string_lower = table.sort, select, string.lower
|
local tbl_sort, select, string_lower = table.sort, select, string.lower
|
||||||
local GetLocale = GetLocale
|
local GetLocale = GetLocale
|
||||||
|
local GetSpellInfo = GetSpellInfo
|
||||||
|
|
||||||
local Gladdy = LibStub("Gladdy")
|
local Gladdy = LibStub("Gladdy")
|
||||||
local L = Gladdy.L
|
local L = Gladdy.L
|
||||||
@ -183,6 +184,30 @@ Gladdy.frameStrataSorting = {
|
|||||||
[8] = "TOOLTIP",
|
[8] = "TOOLTIP",
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Gladdy.exceptionNames = {
|
||||||
|
[50334] = (GetSpellInfo(50334) or "...") .. " Feral", -- Berserk
|
||||||
|
[30151] = select(1, GetSpellInfo(30151)) .. " Felguard", -- Intercept
|
||||||
|
[30194] = select(1, GetSpellInfo(30151)) .. " Felguard", -- Intercept
|
||||||
|
[30198] = select(1, GetSpellInfo(30151)) .. " Felguard", -- Intercept
|
||||||
|
[47996] = select(1, GetSpellInfo(30151)) .. " Felguard", -- Intercept
|
||||||
|
[31117] = select(1, GetSpellInfo(30405)) .. " Silence", -- Unstable Affliction Silence
|
||||||
|
[43523] = select(1, GetSpellInfo(30405)) .. " Silence",
|
||||||
|
[24131] = select(1, GetSpellInfo(19386)) .. " Dot", -- Wyvern Sting Dot
|
||||||
|
[24134] = select(1, GetSpellInfo(19386)) .. " Dot",
|
||||||
|
[24135] = select(1, GetSpellInfo(19386)) .. " Dot",
|
||||||
|
[27069] = select(1, GetSpellInfo(19386)) .. " Dot",
|
||||||
|
[49009] = select(1, GetSpellInfo(19386)) .. " Dot",
|
||||||
|
[49010] = select(1, GetSpellInfo(19386)) .. " Dot",
|
||||||
|
[19975] = select(1, GetSpellInfo(27010)) .. " " .. select(1, GetSpellInfo(16689)), -- Entangling Roots Nature's Grasp
|
||||||
|
[19974] = select(1, GetSpellInfo(27010)) .. " " .. select(1, GetSpellInfo(16689)),
|
||||||
|
[19973] = select(1, GetSpellInfo(27010)) .. " " .. select(1, GetSpellInfo(16689)),
|
||||||
|
[19972] = select(1, GetSpellInfo(27010)) .. " " .. select(1, GetSpellInfo(16689)),
|
||||||
|
[19971] = select(1, GetSpellInfo(27010)) .. " " .. select(1, GetSpellInfo(16689)),
|
||||||
|
[19971] = select(1, GetSpellInfo(27010)) .. " " .. select(1, GetSpellInfo(16689)),
|
||||||
|
[27010] = select(1, GetSpellInfo(27010)) .. " " .. select(1, GetSpellInfo(16689)),
|
||||||
|
[53312] = select(1, GetSpellInfo(27010)) .. " " .. select(1, GetSpellInfo(16689)),
|
||||||
|
}
|
||||||
|
|
||||||
local dispelTypeColors = {}
|
local dispelTypeColors = {}
|
||||||
dispelTypeColors["none"] = { r = 0.80, g = 0, b = 0, a = 1 }
|
dispelTypeColors["none"] = { r = 0.80, g = 0, b = 0, a = 1 }
|
||||||
dispelTypeColors["magic"] = { r = 0.20, g = 0.60, b = 1.00, a = 1 }
|
dispelTypeColors["magic"] = { r = 0.20, g = 0.60, b = 1.00, a = 1 }
|
||||||
@ -292,4 +317,325 @@ local pvpTrinkets = { -- [itemID] = cd in ms
|
|||||||
|
|
||||||
function Gladdy:GetPvpTrinkets()
|
function Gladdy:GetPvpTrinkets()
|
||||||
return pvpTrinkets
|
return pvpTrinkets
|
||||||
|
end
|
||||||
|
|
||||||
|
---------------------
|
||||||
|
-- TOTEM STUFF
|
||||||
|
---------------------
|
||||||
|
|
||||||
|
local totemData = {
|
||||||
|
-- Fire
|
||||||
|
[string_lower("Searing Totem")] = {id = 3599,texture = select(3, GetSpellInfo(3599)), color = {r = 0, g = 0, b = 0, a = 1}},
|
||||||
|
[string_lower("Flametongue Totem")] = {id = 8227,texture = select(3, GetSpellInfo(8227)), color = {r = 0, g = 0, b = 0, a = 1}},
|
||||||
|
[string_lower("Magma Totem")] = {id = 8190,texture = select(3, GetSpellInfo(8190)), color = {r = 0, g = 0, b = 0, a = 1}, pulse = 2},
|
||||||
|
[string_lower("Fire Nova Totem")] = {id = 1535,texture = select(3, GetSpellInfo(1535)), color = {r = 0, g = 0, b = 0, a = 1}, pulse = { cd = 4, once = true }},
|
||||||
|
[string_lower("Totem of Wrath")] = {id = 30706,texture = select(3, GetSpellInfo(30706)), color = {r = 0, g = 0, b = 0, a = 1}},
|
||||||
|
[string_lower("Fire Elemental Totem")] = {id = 32982,texture = select(3, GetSpellInfo(32982)), color = {r = 0, g = 0, b = 0, a = 1}},
|
||||||
|
[string_lower("Frost Resistance Totem")] = {id = 8181,texture = select(3, GetSpellInfo(8181)), color = {r = 0, g = 0, b = 0, a = 1}},
|
||||||
|
-- Water
|
||||||
|
[string_lower("Fire Resistance Totem")] = {id = 8184,texture = select(3, GetSpellInfo(8184)), color = {r = 0, g = 0, b = 0, a = 1}},
|
||||||
|
[string_lower("Disease Cleansing Totem")] = {id = 8170,texture = select(3, GetSpellInfo(8170)), color = {r = 0, g = 0, b = 0, a = 1}, pulse = 5},
|
||||||
|
[string_lower("Healing Stream Totem")] = {id = 5394,texture = select(3, GetSpellInfo(5394)), color = {r = 0, g = 0, b = 0, a = 1}, pulse = 2},
|
||||||
|
[string_lower("Mana Tide Totem")] = {id = 16190,texture = select(3, GetSpellInfo(16190)), color = {r = 0.078, g = 0.9, b = 0.16, a = 1}, pulse = 3 },
|
||||||
|
[string_lower("Mana Spring Totem")] = {id = 5675,texture = select(3, GetSpellInfo(5675)), color = {r = 0, g = 0, b = 0, a = 1}, pulse = 2},
|
||||||
|
-- Earth
|
||||||
|
[string_lower("Earthbind Totem")] = {id = 2484,texture = select(3, GetSpellInfo(2484)), color = {r = 0.5, g = 0.5, b = 0.5, a = 1}, pulse = 3},
|
||||||
|
[string_lower("Stoneclaw Totem")] = {id = 5730,texture = select(3, GetSpellInfo(5730)), color = {r = 0, g = 0, b = 0, a = 1}, pulse = 2},
|
||||||
|
[string_lower("Stoneskin Totem")] = {id = 8071,texture = select(3, GetSpellInfo(8071)), color = {r = 0, g = 0, b = 0, a = 1}},
|
||||||
|
[string_lower("Strength of Earth Totem")] = {id = 8075,texture = select(3, GetSpellInfo(8075)), color = {r = 0, g = 0, b = 0, a = 1}},
|
||||||
|
[string_lower("Earth Elemental Totem")] = {id = 33663,texture = select(3, GetSpellInfo(33663)), color = {r = 0, g = 0, b = 0, a = 1}},
|
||||||
|
[string_lower("Tremor Totem")] = {id = 8143,texture = select(3, GetSpellInfo(8143)), color = {r = 1, g = 0.9, b = 0.1, a = 1}, pulse = 3},
|
||||||
|
-- Air
|
||||||
|
[string_lower("Grounding Totem")] = {id = 8177,texture = select(3, GetSpellInfo(8177)), color = {r = 0, g = 0.53, b = 0.92, a = 1}},
|
||||||
|
[string_lower("Nature Resistance Totem")] = {id = 10595,texture = select(3, GetSpellInfo(10595)), color = {r = 0, g = 0, b = 0, a = 1}},
|
||||||
|
[string_lower("Windfury Totem")] = {id = 8512,texture = select(3, GetSpellInfo(8512)), color = {r = 0.96, g = 0, b = 0.07, a = 1}},
|
||||||
|
[string_lower("Sentry Totem")] = {id = 6495, texture = select(3, GetSpellInfo(6495)), color = {r = 0, g = 0, b = 0, a = 1}},
|
||||||
|
[string_lower("Wrath of Air Totem")] = {id = 3738,texture = select(3, GetSpellInfo(3738)), color = {r = 0, g = 0, b = 0, a = 1}},
|
||||||
|
}
|
||||||
|
|
||||||
|
local totemSpellIdToPulse = {
|
||||||
|
[GetSpellInfo(totemData[string_lower("Earthbind Totem")].id)] = totemData[string_lower("Earthbind Totem")].pulse,
|
||||||
|
[2484] = totemData[string_lower("Earthbind Totem")].pulse,
|
||||||
|
[GetSpellInfo(totemData[string_lower("Tremor Totem")].id)] = totemData[string_lower("Tremor Totem")].pulse,
|
||||||
|
[8143] = totemData[string_lower("Tremor Totem")].pulse,
|
||||||
|
[GetSpellInfo(totemData[string_lower("Disease Cleansing Totem")].id)] = totemData[string_lower("Disease Cleansing Totem")].pulse,
|
||||||
|
[8170] = totemData[string_lower("Disease Cleansing Totem")].pulse,
|
||||||
|
[GetSpellInfo(totemData[string_lower("Fire Nova Totem")].id)] = totemData[string_lower("Fire Nova Totem")].pulse,
|
||||||
|
[1535] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 1
|
||||||
|
[8498] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 2
|
||||||
|
[8499] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 3
|
||||||
|
[11314] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 4
|
||||||
|
[11315] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 5
|
||||||
|
[25546] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 6
|
||||||
|
[25547] = totemData[string_lower("Fire Nova Totem")].pulse, -- Rank 7
|
||||||
|
[GetSpellInfo(totemData[string_lower("Magma Totem")].id)] = totemData[string_lower("Magma Totem")].pulse,
|
||||||
|
[8190] = totemData[string_lower("Magma Totem")].pulse, -- Rank 1
|
||||||
|
[10585] = totemData[string_lower("Magma Totem")].pulse, -- Rank 2
|
||||||
|
[10586] = totemData[string_lower("Magma Totem")].pulse, -- Rank 3
|
||||||
|
[10587] = totemData[string_lower("Magma Totem")].pulse, -- Rank 4
|
||||||
|
[25552] = totemData[string_lower("Magma Totem")].pulse, -- Rank 5
|
||||||
|
[58731] = totemData[string_lower("Magma Totem")].pulse, -- Rank 6
|
||||||
|
[58734] = totemData[string_lower("Magma Totem")].pulse, -- Rank 7
|
||||||
|
[GetSpellInfo(totemData[string_lower("Healing Stream Totem")].id)] = totemData[string_lower("Healing Stream Totem")].pulse,
|
||||||
|
[5394] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 1
|
||||||
|
[6375] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 2
|
||||||
|
[6377] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 3
|
||||||
|
[10462] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 4
|
||||||
|
[10463] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 5
|
||||||
|
[25567] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 6
|
||||||
|
[58755] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 7
|
||||||
|
[58756] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 8
|
||||||
|
[58757] = totemData[string_lower("Healing Stream Totem")].pulse, -- Rank 9
|
||||||
|
[GetSpellInfo(totemData[string_lower("Mana Tide Totem")].id)] = totemData[string_lower("Mana Tide Totem")].pulse,
|
||||||
|
[16190] = totemData[string_lower("Mana Tide Totem")].pulse, -- Rank 1
|
||||||
|
[GetSpellInfo(totemData[string_lower("Stoneclaw Totem")].id)] = totemData[string_lower("Stoneclaw Totem")].pulse,
|
||||||
|
[5730] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 1
|
||||||
|
[6390] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 2
|
||||||
|
[6391] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 3
|
||||||
|
[6392] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 4
|
||||||
|
[10427] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 5
|
||||||
|
[10428] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 6
|
||||||
|
[25525] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 7
|
||||||
|
[58580] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 8
|
||||||
|
[58581] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 9
|
||||||
|
[58582] = totemData[string_lower("Stoneclaw Totem")].pulse, -- Rank 10
|
||||||
|
}
|
||||||
|
|
||||||
|
local totemNpcIdsToTotemData = {
|
||||||
|
--fire
|
||||||
|
[2523] = totemData[string_lower("Searing Totem")],
|
||||||
|
[3902] = totemData[string_lower("Searing Totem")],
|
||||||
|
[3903] = totemData[string_lower("Searing Totem")],
|
||||||
|
[3904] = totemData[string_lower("Searing Totem")],
|
||||||
|
[7400] = totemData[string_lower("Searing Totem")],
|
||||||
|
[7402] = totemData[string_lower("Searing Totem")],
|
||||||
|
[15480] = totemData[string_lower("Searing Totem")],
|
||||||
|
[31162] = totemData[string_lower("Searing Totem")],
|
||||||
|
[31164] = totemData[string_lower("Searing Totem")],
|
||||||
|
[31165] = totemData[string_lower("Searing Totem")],
|
||||||
|
[21995] = totemData[string_lower("Searing Totem")],
|
||||||
|
[22209] = totemData[string_lower("Searing Totem")],
|
||||||
|
[22895] = totemData[string_lower("Searing Totem")],
|
||||||
|
[22896] = totemData[string_lower("Searing Totem")],
|
||||||
|
[34687] = totemData[string_lower("Searing Totem")],
|
||||||
|
[36532] = totemData[string_lower("Searing Totem")],
|
||||||
|
[43423] = totemData[string_lower("Searing Totem")],
|
||||||
|
[67380] = totemData[string_lower("Searing Totem")],
|
||||||
|
[73477] = totemData[string_lower("Searing Totem")],
|
||||||
|
[79238] = totemData[string_lower("Searing Totem")],
|
||||||
|
[22896] = totemData[string_lower("Searing Totem")],
|
||||||
|
[84519] = totemData[string_lower("Searing Totem")],
|
||||||
|
[110730] = totemData[string_lower("Searing Totem")],
|
||||||
|
[132178] = totemData[string_lower("Searing Totem")],
|
||||||
|
[9637] = totemData[string_lower("Searing Totem")],
|
||||||
|
|
||||||
|
[5950] = totemData[string_lower("Flametongue Totem")],
|
||||||
|
[6012] = totemData[string_lower("Flametongue Totem")],
|
||||||
|
[7423] = totemData[string_lower("Flametongue Totem")],
|
||||||
|
[10557] = totemData[string_lower("Flametongue Totem")],
|
||||||
|
[15485] = totemData[string_lower("Flametongue Totem")],
|
||||||
|
[31132] = totemData[string_lower("Flametongue Totem")],
|
||||||
|
[31133] = totemData[string_lower("Flametongue Totem")],
|
||||||
|
[31158] = totemData[string_lower("Flametongue Totem")],
|
||||||
|
[42605] = totemData[string_lower("Flametongue Totem")],
|
||||||
|
|
||||||
|
[5929] = totemData[string_lower("Magma Totem")],
|
||||||
|
[7464] = totemData[string_lower("Magma Totem")],
|
||||||
|
[7465] = totemData[string_lower("Magma Totem")],
|
||||||
|
[7466] = totemData[string_lower("Magma Totem")],
|
||||||
|
[15484] = totemData[string_lower("Magma Totem")],
|
||||||
|
[31166] = totemData[string_lower("Magma Totem")],
|
||||||
|
[31167] = totemData[string_lower("Magma Totem")],
|
||||||
|
[32887] = totemData[string_lower("Magma Totem")],
|
||||||
|
[42211] = totemData[string_lower("Magma Totem")],
|
||||||
|
[71335] = totemData[string_lower("Magma Totem")],
|
||||||
|
[71925] = totemData[string_lower("Magma Totem")],
|
||||||
|
[73085] = totemData[string_lower("Magma Totem")],
|
||||||
|
[73093] = totemData[string_lower("Magma Totem")],
|
||||||
|
[73268] = totemData[string_lower("Magma Totem")],
|
||||||
|
[88971] = totemData[string_lower("Magma Totem")],
|
||||||
|
[97369] = totemData[string_lower("Magma Totem")],
|
||||||
|
[98676] = totemData[string_lower("Magma Totem")],
|
||||||
|
|
||||||
|
[5879] = totemData[string_lower("Fire Nova Totem")],
|
||||||
|
[6110] = totemData[string_lower("Fire Nova Totem")],
|
||||||
|
[6111] = totemData[string_lower("Fire Nova Totem")],
|
||||||
|
[7844] = totemData[string_lower("Fire Nova Totem")],
|
||||||
|
[7845] = totemData[string_lower("Fire Nova Totem")],
|
||||||
|
[14662] = totemData[string_lower("Fire Nova Totem")],
|
||||||
|
[15482] = totemData[string_lower("Fire Nova Totem")],
|
||||||
|
[15483] = totemData[string_lower("Fire Nova Totem")],
|
||||||
|
[24320] = totemData[string_lower("Fire Nova Totem")],
|
||||||
|
[32775] = totemData[string_lower("Fire Nova Totem")],
|
||||||
|
[32776] = totemData[string_lower("Fire Nova Totem")],
|
||||||
|
|
||||||
|
[17539] = totemData[string_lower("Totem of Wrath")],
|
||||||
|
[22970] = totemData[string_lower("Totem of Wrath")],
|
||||||
|
[22971] = totemData[string_lower("Totem of Wrath")],
|
||||||
|
[30652] = totemData[string_lower("Totem of Wrath")],
|
||||||
|
[30653] = totemData[string_lower("Totem of Wrath")],
|
||||||
|
[30654] = totemData[string_lower("Totem of Wrath")],
|
||||||
|
|
||||||
|
[15439] = totemData[string_lower("Fire Elemental Totem")],
|
||||||
|
[40830] = totemData[string_lower("Fire Elemental Totem")],
|
||||||
|
[41337] = totemData[string_lower("Fire Elemental Totem")],
|
||||||
|
[41346] = totemData[string_lower("Fire Elemental Totem")],
|
||||||
|
[72301] = totemData[string_lower("Fire Elemental Totem")],
|
||||||
|
|
||||||
|
[5926] = totemData[string_lower("Frost Resistance Totem")],
|
||||||
|
[7412] = totemData[string_lower("Frost Resistance Totem")],
|
||||||
|
[7413] = totemData[string_lower("Frost Resistance Totem")],
|
||||||
|
[15486] = totemData[string_lower("Frost Resistance Totem")],
|
||||||
|
[31171] = totemData[string_lower("Frost Resistance Totem")],
|
||||||
|
[31172] = totemData[string_lower("Frost Resistance Totem")],
|
||||||
|
|
||||||
|
-- Water
|
||||||
|
[5927] = totemData[string_lower("Fire Resistance Totem")],
|
||||||
|
[7424] = totemData[string_lower("Fire Resistance Totem")],
|
||||||
|
[7425] = totemData[string_lower("Fire Resistance Totem")],
|
||||||
|
[15487] = totemData[string_lower("Fire Resistance Totem")],
|
||||||
|
[31169] = totemData[string_lower("Fire Resistance Totem")],
|
||||||
|
[31170] = totemData[string_lower("Fire Resistance Totem")],
|
||||||
|
|
||||||
|
[5924] = totemData[string_lower("Disease Cleansing Totem")],
|
||||||
|
|
||||||
|
[3527] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[3906] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[3907] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[3908] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[3909] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[14664] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[15488] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[18235] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[31181] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[31182] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[31185] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[34686] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[36542] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[37810] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[38428] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[47077] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[72309] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[72457] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[73890] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[74433] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[97508] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[112567] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[120357] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[128539] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
[132049] = totemData[string_lower("Healing Stream Totem")],
|
||||||
|
|
||||||
|
[10467] = totemData[string_lower("Mana Tide Totem")],
|
||||||
|
[11100] = totemData[string_lower("Mana Tide Totem")],
|
||||||
|
[11101] = totemData[string_lower("Mana Tide Totem")],
|
||||||
|
[17061] = totemData[string_lower("Mana Tide Totem")],
|
||||||
|
|
||||||
|
[3573] = totemData[string_lower("Mana Spring Totem")],
|
||||||
|
[7414] = totemData[string_lower("Mana Spring Totem")],
|
||||||
|
[7415] = totemData[string_lower("Mana Spring Totem")],
|
||||||
|
[7416] = totemData[string_lower("Mana Spring Totem")],
|
||||||
|
[15304] = totemData[string_lower("Mana Spring Totem")],
|
||||||
|
[15489] = totemData[string_lower("Mana Spring Totem")],
|
||||||
|
[31186] = totemData[string_lower("Mana Spring Totem")],
|
||||||
|
[31189] = totemData[string_lower("Mana Spring Totem")],
|
||||||
|
[31190] = totemData[string_lower("Mana Spring Totem")],
|
||||||
|
|
||||||
|
-- Earth
|
||||||
|
[2630] = totemData[string_lower("Earthbind Totem")],
|
||||||
|
[22486] = totemData[string_lower("Earthbind Totem")],
|
||||||
|
[40233] = totemData[string_lower("Earthbind Totem")],
|
||||||
|
[74737] = totemData[string_lower("Earthbind Totem")],
|
||||||
|
[79155] = totemData[string_lower("Earthbind Totem")],
|
||||||
|
|
||||||
|
[3579] = totemData[string_lower("Stoneclaw Totem")],
|
||||||
|
[3911] = totemData[string_lower("Stoneclaw Totem")],
|
||||||
|
[3912] = totemData[string_lower("Stoneclaw Totem")],
|
||||||
|
[3913] = totemData[string_lower("Stoneclaw Totem")],
|
||||||
|
[7398] = totemData[string_lower("Stoneclaw Totem")],
|
||||||
|
[7399] = totemData[string_lower("Stoneclaw Totem")],
|
||||||
|
[14870] = totemData[string_lower("Stoneclaw Totem")],
|
||||||
|
[15478] = totemData[string_lower("Stoneclaw Totem")],
|
||||||
|
[31120] = totemData[string_lower("Stoneclaw Totem")],
|
||||||
|
[31121] = totemData[string_lower("Stoneclaw Totem")],
|
||||||
|
[31122] = totemData[string_lower("Stoneclaw Totem")],
|
||||||
|
[40258] = totemData[string_lower("Stoneclaw Totem")],
|
||||||
|
[102402] = totemData[string_lower("Stoneclaw Totem")],
|
||||||
|
|
||||||
|
[5873] = totemData[string_lower("Stoneskin Totem")],
|
||||||
|
[5919] = totemData[string_lower("Stoneskin Totem")],
|
||||||
|
[5920] = totemData[string_lower("Stoneskin Totem")],
|
||||||
|
[7366] = totemData[string_lower("Stoneskin Totem")],
|
||||||
|
[7367] = totemData[string_lower("Stoneskin Totem")],
|
||||||
|
[7368] = totemData[string_lower("Stoneskin Totem")],
|
||||||
|
[14663] = totemData[string_lower("Stoneskin Totem")],
|
||||||
|
[15470] = totemData[string_lower("Stoneskin Totem")],
|
||||||
|
[15474] = totemData[string_lower("Stoneskin Totem")],
|
||||||
|
[18177] = totemData[string_lower("Stoneskin Totem")],
|
||||||
|
[21994] = totemData[string_lower("Stoneskin Totem")],
|
||||||
|
[31175] = totemData[string_lower("Stoneskin Totem")],
|
||||||
|
[31176] = totemData[string_lower("Stoneskin Totem")],
|
||||||
|
[36550] = totemData[string_lower("Stoneskin Totem")],
|
||||||
|
[40267] = totemData[string_lower("Stoneskin Totem")],
|
||||||
|
[41967] = totemData[string_lower("Stoneskin Totem")],
|
||||||
|
|
||||||
|
[5874] = totemData[string_lower("Strength of Earth Totem")],
|
||||||
|
[5921] = totemData[string_lower("Strength of Earth Totem")],
|
||||||
|
[5922] = totemData[string_lower("Strength of Earth Totem")],
|
||||||
|
[7403] = totemData[string_lower("Strength of Earth Totem")],
|
||||||
|
[15464] = totemData[string_lower("Strength of Earth Totem")],
|
||||||
|
[15479] = totemData[string_lower("Strength of Earth Totem")],
|
||||||
|
[21992] = totemData[string_lower("Strength of Earth Totem")],
|
||||||
|
[30647] = totemData[string_lower("Strength of Earth Totem")],
|
||||||
|
[31129] = totemData[string_lower("Strength of Earth Totem")],
|
||||||
|
[40266] = totemData[string_lower("Strength of Earth Totem")],
|
||||||
|
|
||||||
|
[15430] = totemData[string_lower("Earth Elemental Totem")],
|
||||||
|
[24649] = totemData[string_lower("Earth Elemental Totem")],
|
||||||
|
[39387] = totemData[string_lower("Earth Elemental Totem")],
|
||||||
|
[40247] = totemData[string_lower("Earth Elemental Totem")],
|
||||||
|
[72307] = totemData[string_lower("Earth Elemental Totem")],
|
||||||
|
|
||||||
|
[5913] = totemData[string_lower("Tremor Totem")],
|
||||||
|
[41938] = totemData[string_lower("Tremor Totem")],
|
||||||
|
[41939] = totemData[string_lower("Tremor Totem")],
|
||||||
|
|
||||||
|
-- Air
|
||||||
|
[5925] = totemData[string_lower("Grounding Totem")],
|
||||||
|
[128537] = totemData[string_lower("Grounding Totem")],
|
||||||
|
[136251] = totemData[string_lower("Grounding Totem")],
|
||||||
|
|
||||||
|
[7467] = totemData[string_lower("Nature Resistance Totem")],
|
||||||
|
[7468] = totemData[string_lower("Nature Resistance Totem")],
|
||||||
|
[7469] = totemData[string_lower("Nature Resistance Totem")],
|
||||||
|
[15490] = totemData[string_lower("Nature Resistance Totem")],
|
||||||
|
[31173] = totemData[string_lower("Nature Resistance Totem")],
|
||||||
|
[31174] = totemData[string_lower("Nature Resistance Totem")],
|
||||||
|
|
||||||
|
[6112] = totemData[string_lower("Windfury Totem")],
|
||||||
|
[7483] = totemData[string_lower("Windfury Totem")],
|
||||||
|
[7484] = totemData[string_lower("Windfury Totem")],
|
||||||
|
[14666] = totemData[string_lower("Windfury Totem")],
|
||||||
|
[15496] = totemData[string_lower("Windfury Totem")],
|
||||||
|
[15497] = totemData[string_lower("Windfury Totem")],
|
||||||
|
[22897] = totemData[string_lower("Windfury Totem")],
|
||||||
|
[41940] = totemData[string_lower("Windfury Totem")],
|
||||||
|
[41941] = totemData[string_lower("Windfury Totem")],
|
||||||
|
[80703] = totemData[string_lower("Windfury Totem")],
|
||||||
|
[105690] = totemData[string_lower("Windfury Totem")],
|
||||||
|
[133684] = totemData[string_lower("Windfury Totem")],
|
||||||
|
|
||||||
|
[3968] = totemData[string_lower("Sentry Totem")],
|
||||||
|
[28938] = totemData[string_lower("Sentry Totem")],
|
||||||
|
[40187] = totemData[string_lower("Sentry Totem")],
|
||||||
|
[69505] = totemData[string_lower("Sentry Totem")],
|
||||||
|
[70413] = totemData[string_lower("Sentry Totem")],
|
||||||
|
[71145] = totemData[string_lower("Sentry Totem")],
|
||||||
|
[147410] = totemData[string_lower("Sentry Totem")],
|
||||||
|
|
||||||
|
[15447] = totemData[string_lower("Wrath of Air Totem")],
|
||||||
|
[36556] = totemData[string_lower("Wrath of Air Totem")],
|
||||||
|
}
|
||||||
|
|
||||||
|
function Gladdy:GetSharedTotemData()
|
||||||
|
return totemData, totemNpcIdsToTotemData, totemSpellIdToPulse
|
||||||
end
|
end
|
@ -1,4 +1,6 @@
|
|||||||
local select, string_gsub, tostring, pairs, ipairs = select, string.gsub, tostring, pairs, ipairs
|
local select, string_gsub, tostring, pairs, ipairs = select, string.gsub, tostring, pairs, ipairs
|
||||||
|
local wipe = wipe
|
||||||
|
local unpack = unpack
|
||||||
|
|
||||||
local CombatLogGetCurrentEventInfo = CombatLogGetCurrentEventInfo
|
local CombatLogGetCurrentEventInfo = CombatLogGetCurrentEventInfo
|
||||||
local AURA_TYPE_DEBUFF = AURA_TYPE_DEBUFF
|
local AURA_TYPE_DEBUFF = AURA_TYPE_DEBUFF
|
||||||
@ -34,10 +36,11 @@ function EventListener:JOINED_ARENA()
|
|||||||
self:RegisterEvent("UNIT_SPELLCAST_START")
|
self:RegisterEvent("UNIT_SPELLCAST_START")
|
||||||
self:RegisterEvent("UNIT_SPELLCAST_CHANNEL_START")
|
self:RegisterEvent("UNIT_SPELLCAST_CHANNEL_START")
|
||||||
self:RegisterEvent("UNIT_SPELLCAST_SUCCEEDED")
|
self:RegisterEvent("UNIT_SPELLCAST_SUCCEEDED")
|
||||||
self:SetScript("OnEvent", EventListener.OnEvent)
|
|
||||||
|
|
||||||
-- in case arena has started already we check for units
|
-- in case arena has started already we check for units
|
||||||
for i=1,Gladdy.curBracket do
|
for i=1,Gladdy.curBracket do
|
||||||
|
if Gladdy.buttons["arena"..i].lastAuras then
|
||||||
|
wipe(Gladdy.buttons["arena"..i].lastAuras)
|
||||||
|
end
|
||||||
if UnitExists("arena" .. i) then
|
if UnitExists("arena" .. i) then
|
||||||
Gladdy:SpotEnemy("arena" .. i, true)
|
Gladdy:SpotEnemy("arena" .. i, true)
|
||||||
end
|
end
|
||||||
@ -45,6 +48,7 @@ function EventListener:JOINED_ARENA()
|
|||||||
Gladdy:SendMessage("PET_SPOTTED", "arenapet" .. i)
|
Gladdy:SendMessage("PET_SPOTTED", "arenapet" .. i)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
self:SetScript("OnEvent", EventListener.OnEvent)
|
||||||
end
|
end
|
||||||
|
|
||||||
function EventListener:Reset()
|
function EventListener:Reset()
|
||||||
@ -57,7 +61,6 @@ function Gladdy:SpotEnemy(unit, auraScan)
|
|||||||
if not unit or not button then
|
if not unit or not button then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
button.stealthed = false
|
|
||||||
if UnitExists(unit) then
|
if UnitExists(unit) then
|
||||||
button.raceLoc = UnitRace(unit)
|
button.raceLoc = UnitRace(unit)
|
||||||
button.race = select(2, UnitRace(unit))
|
button.race = select(2, UnitRace(unit))
|
||||||
@ -77,6 +80,11 @@ function Gladdy:SpotEnemy(unit, auraScan)
|
|||||||
Gladdy:SendMessage("AURA_GAIN_LIMIT", unit, AURA_TYPE_BUFF, n - 1)
|
Gladdy:SendMessage("AURA_GAIN_LIMIT", unit, AURA_TYPE_BUFF, n - 1)
|
||||||
break
|
break
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if Gladdy.exceptionNames[spellID] then
|
||||||
|
spellName = Gladdy.exceptionNames[spellID]
|
||||||
|
end
|
||||||
|
|
||||||
if Gladdy.specBuffs[spellName] and unitCaster then -- Check for auras that detect a spec
|
if Gladdy.specBuffs[spellName] and unitCaster then -- Check for auras that detect a spec
|
||||||
local unitPet = string_gsub(unit, "%d$", "pet%1")
|
local unitPet = string_gsub(unit, "%d$", "pet%1")
|
||||||
if UnitIsUnit(unit, unitCaster) or UnitIsUnit(unitPet, unitCaster) then
|
if UnitIsUnit(unit, unitCaster) or UnitIsUnit(unitPet, unitCaster) then
|
||||||
@ -108,15 +116,10 @@ function EventListener:COMBAT_LOG_EVENT_UNFILTERED()
|
|||||||
Gladdy.modules["Shadowsight Timer"]:AURA_GAIN(nil, nil, 34709)
|
Gladdy.modules["Shadowsight Timer"]:AURA_GAIN(nil, nil, 34709)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if Gladdy.exceptionNames[spellID] then
|
||||||
|
spellName = Gladdy.exceptionNames[spellID]
|
||||||
|
end
|
||||||
if destUnit then
|
if destUnit then
|
||||||
-- cooldown
|
|
||||||
if (Gladdy.db.cooldown and Cooldowns.cooldownSpellIds[spellName]) then
|
|
||||||
local spellId = Cooldowns.cooldownSpellIds[spellName] -- don't use spellId from combatlog, in case of different spellrank
|
|
||||||
if spellID == 16188 or spellID == 17116 then -- Nature's Swiftness (same name for druid and shaman)
|
|
||||||
spellId = spellID
|
|
||||||
end
|
|
||||||
Cooldowns:AURA_FADE(destUnit, spellID)
|
|
||||||
end
|
|
||||||
-- diminish tracker
|
-- diminish tracker
|
||||||
if Gladdy.buttons[destUnit] and Gladdy.db.drEnabled and extraSpellId == AURA_TYPE_DEBUFF then
|
if Gladdy.buttons[destUnit] and Gladdy.db.drEnabled and extraSpellId == AURA_TYPE_DEBUFF then
|
||||||
if (eventType == "SPELL_AURA_REMOVED") then
|
if (eventType == "SPELL_AURA_REMOVED") then
|
||||||
@ -131,7 +134,7 @@ function EventListener:COMBAT_LOG_EVENT_UNFILTERED()
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
-- death detection
|
-- death detection
|
||||||
if (Gladdy.buttons[destUnit] and eventType == "UNIT_DIED" or eventType == "PARTY_KILL" or eventType == "SPELL_INSTAKILL") then
|
if (eventType == "UNIT_DIED" or eventType == "PARTY_KILL" or eventType == "SPELL_INSTAKILL") then
|
||||||
if not Gladdy:isFeignDeath(destUnit) then
|
if not Gladdy:isFeignDeath(destUnit) then
|
||||||
Gladdy:SendMessage("UNIT_DEATH", destUnit)
|
Gladdy:SendMessage("UNIT_DEATH", destUnit)
|
||||||
end
|
end
|
||||||
@ -156,8 +159,7 @@ function EventListener:COMBAT_LOG_EVENT_UNFILTERED()
|
|||||||
if not Gladdy.buttons[srcUnit].spec then
|
if not Gladdy.buttons[srcUnit].spec then
|
||||||
self:DetectSpec(srcUnit, Gladdy.specSpells[spellName])
|
self:DetectSpec(srcUnit, Gladdy.specSpells[spellName])
|
||||||
end
|
end
|
||||||
if (eventType == "SPELL_CAST_SUCCESS" or eventType == "SPELL_AURA_APPLIED" or eventType == "SPELL_MISSED") then
|
if (eventType == "SPELL_CAST_SUCCESS" or eventType == "SPELL_MISSED") then
|
||||||
self:DetectSpec(srcUnit, Gladdy.specSpells[spellName])
|
|
||||||
-- cooldown tracker
|
-- cooldown tracker
|
||||||
if Gladdy.db.cooldown and Cooldowns.cooldownSpellIds[spellName] then
|
if Gladdy.db.cooldown and Cooldowns.cooldownSpellIds[spellName] then
|
||||||
local unitClass
|
local unitClass
|
||||||
@ -165,23 +167,34 @@ function EventListener:COMBAT_LOG_EVENT_UNFILTERED()
|
|||||||
if spellID == 16188 or spellID == 17116 then -- Nature's Swiftness (same name for druid and shaman)
|
if spellID == 16188 or spellID == 17116 then -- Nature's Swiftness (same name for druid and shaman)
|
||||||
spellId = spellID
|
spellId = spellID
|
||||||
end
|
end
|
||||||
if Gladdy.db.cooldownCooldowns[tostring(spellId)] then
|
if Gladdy.db.cooldownCooldowns[tostring(spellId)] and (eventType == "SPELL_CAST_SUCCESS" or eventType == "SPELL_MISSED" or eventType == "SPELL_DODGED") then
|
||||||
if (Gladdy:GetCooldownList()[Gladdy.buttons[srcUnit].class][spellId]) then
|
if (Gladdy:GetCooldownList()[Gladdy.buttons[srcUnit].class][spellId]) then
|
||||||
unitClass = Gladdy.buttons[srcUnit].class
|
unitClass = Gladdy.buttons[srcUnit].class
|
||||||
else
|
else
|
||||||
unitClass = Gladdy.buttons[srcUnit].race
|
unitClass = Gladdy.buttons[srcUnit].race
|
||||||
end
|
end
|
||||||
if spellID ~= 16188 and spellID ~= 17116 then -- Nature's Swiftness CD starts when buff fades
|
if spellID ~= 16188 and spellID ~= 17116 and spellID ~= 16166 and spellID ~= 12043 and spellID ~= 5384 then -- Nature's Swiftness CD starts when buff fades
|
||||||
Gladdy:Debug("INFO", "SPELL_CAST_SUCCESS - CooldownUsed", srcUnit, "spellID:", spellID)
|
Gladdy:Debug("INFO", eventType, "- CooldownUsed", srcUnit, "spellID:", spellID)
|
||||||
Cooldowns:CooldownUsed(srcUnit, unitClass, spellId)
|
Cooldowns:CooldownUsed(srcUnit, unitClass, spellId)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if (eventType == "SPELL_AURA_REMOVED" and (spellID == 16188 or spellID == 17116) and Gladdy.buttons[srcUnit].class) then
|
if (eventType == "SPELL_AURA_REMOVED" and (spellID == 16188 or spellID == 17116 or spellID == 16166 or spellID == 12043) and Gladdy.buttons[srcUnit].class) then
|
||||||
Gladdy:Debug("INFO", "SPELL_AURA_REMOVED - CooldownUsed", srcUnit, "spellID:", spellID)
|
Gladdy:Debug("INFO", "SPELL_AURA_REMOVED - CooldownUsed", srcUnit, "spellID:", spellID)
|
||||||
Cooldowns:CooldownUsed(srcUnit, Gladdy.buttons[srcUnit].class, spellID)
|
Cooldowns:CooldownUsed(srcUnit, Gladdy.buttons[srcUnit].class, spellID)
|
||||||
end
|
end
|
||||||
|
if (eventType == "SPELL_AURA_REMOVED" and Gladdy.db.cooldown and Cooldowns.cooldownSpellIds[spellName]) then
|
||||||
|
local unit = Gladdy:GetArenaUnit(srcUnit, true)
|
||||||
|
local spellId = Cooldowns.cooldownSpellIds[spellName] -- don't use spellId from combatlog, in case of different spellrank
|
||||||
|
if spellID == 16188 or spellID == 17116 then -- Nature's Swiftness (same name for druid and shaman)
|
||||||
|
spellId = spellID
|
||||||
|
end
|
||||||
|
if unit then
|
||||||
|
--Gladdy:Debug("INFO", "EL:CL:SPELL_AURA_REMOVED (srcUnit)", "Cooldowns:AURA_FADE", unit, spellId)
|
||||||
|
Cooldowns:AURA_FADE(unit, spellId)
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -196,6 +209,7 @@ function EventListener:ARENA_OPPONENT_UPDATE(unit, updateReason)
|
|||||||
if updateReason == "seen" then
|
if updateReason == "seen" then
|
||||||
-- ENEMY_SPOTTED
|
-- ENEMY_SPOTTED
|
||||||
if button then
|
if button then
|
||||||
|
button.stealthed = false
|
||||||
Gladdy:SendMessage("ENEMY_STEALTH", unit, false)
|
Gladdy:SendMessage("ENEMY_STEALTH", unit, false)
|
||||||
if not button.class or not button.race then
|
if not button.class or not button.race then
|
||||||
Gladdy:SpotEnemy(unit, true)
|
Gladdy:SpotEnemy(unit, true)
|
||||||
@ -207,6 +221,7 @@ function EventListener:ARENA_OPPONENT_UPDATE(unit, updateReason)
|
|||||||
elseif updateReason == "unseen" then
|
elseif updateReason == "unseen" then
|
||||||
-- STEALTH
|
-- STEALTH
|
||||||
if button then
|
if button then
|
||||||
|
button.stealthed = true
|
||||||
Gladdy:SendMessage("ENEMY_STEALTH", unit, true)
|
Gladdy:SendMessage("ENEMY_STEALTH", unit, true)
|
||||||
end
|
end
|
||||||
if pet then
|
if pet then
|
||||||
@ -226,25 +241,6 @@ function EventListener:ARENA_OPPONENT_UPDATE(unit, updateReason)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
Gladdy.exceptionNames = { -- TODO MOVE ME TO CLASSBUFFS LIB
|
|
||||||
[31117] = GetSpellInfo(30405) .. " Silence", -- Unstable Affliction Silence
|
|
||||||
[43523] = GetSpellInfo(30405) .. " Silence",
|
|
||||||
[24131] = select(1, GetSpellInfo(19386)) .. " Dot", -- Wyvern Sting Dot
|
|
||||||
[24134] = select(1, GetSpellInfo(19386)) .. " Dot",
|
|
||||||
[24135] = select(1, GetSpellInfo(19386)) .. " Dot",
|
|
||||||
[27069] = select(1, GetSpellInfo(19386)) .. " Dot",
|
|
||||||
[49009] = select(1, GetSpellInfo(19386)) .. " Dot",
|
|
||||||
[49010] = select(1, GetSpellInfo(19386)) .. " Dot",
|
|
||||||
[19975] = select(1, GetSpellInfo(27010)) .. " " .. select(1, GetSpellInfo(16689)), -- Entangling Roots Nature's Grasp
|
|
||||||
[19974] = select(1, GetSpellInfo(27010)) .. " " .. select(1, GetSpellInfo(16689)),
|
|
||||||
[19973] = select(1, GetSpellInfo(27010)) .. " " .. select(1, GetSpellInfo(16689)),
|
|
||||||
[19972] = select(1, GetSpellInfo(27010)) .. " " .. select(1, GetSpellInfo(16689)),
|
|
||||||
[19971] = select(1, GetSpellInfo(27010)) .. " " .. select(1, GetSpellInfo(16689)),
|
|
||||||
[19971] = select(1, GetSpellInfo(27010)) .. " " .. select(1, GetSpellInfo(16689)),
|
|
||||||
[27010] = select(1, GetSpellInfo(27010)) .. " " .. select(1, GetSpellInfo(16689)),
|
|
||||||
[53312] = select(1, GetSpellInfo(27010)) .. " " .. select(1, GetSpellInfo(16689)),
|
|
||||||
}
|
|
||||||
|
|
||||||
Gladdy.cooldownBuffs = {
|
Gladdy.cooldownBuffs = {
|
||||||
[GetSpellInfo(6346)] = { cd = function(expTime) -- 180s uptime == cd
|
[GetSpellInfo(6346)] = { cd = function(expTime) -- 180s uptime == cd
|
||||||
return expTime
|
return expTime
|
||||||
@ -275,19 +271,32 @@ function EventListener:UNIT_AURA(unit, isFullUpdate, updatedAuras)
|
|||||||
if not button then
|
if not button then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
if not button.auras then
|
||||||
|
button.auras = {}
|
||||||
|
end
|
||||||
|
wipe(button.auras)
|
||||||
|
if not button.lastAuras then
|
||||||
|
button.lastAuras = {}
|
||||||
|
end
|
||||||
|
Gladdy:Debug("INFO", "AURA_FADE", unit, AURA_TYPE_BUFF, AURA_TYPE_DEBUFF)
|
||||||
|
Gladdy:SendMessage("AURA_FADE", unit, AURA_TYPE_BUFF)
|
||||||
|
Gladdy:SendMessage("AURA_FADE", unit, AURA_TYPE_DEBUFF)
|
||||||
for i = 1, 2 do
|
for i = 1, 2 do
|
||||||
if not Gladdy.buttons[unit].class or not Gladdy.buttons[unit].race then
|
if not Gladdy.buttons[unit].class or not Gladdy.buttons[unit].race then
|
||||||
Gladdy:SpotEnemy(unit, false)
|
Gladdy:SpotEnemy(unit, false)
|
||||||
end
|
end
|
||||||
local filter = (i == 1 and "HELPFUL" or "HARMFUL")
|
local filter = (i == 1 and "HELPFUL" or "HARMFUL")
|
||||||
local auraType = i == 1 and AURA_TYPE_BUFF or AURA_TYPE_DEBUFF
|
local auraType = i == 1 and AURA_TYPE_BUFF or AURA_TYPE_DEBUFF
|
||||||
Gladdy:SendMessage("AURA_FADE", unit, auraType)
|
|
||||||
for n = 1, 30 do
|
for n = 1, 30 do
|
||||||
local spellName, texture, count, dispelType, duration, expirationTime, unitCaster, _, shouldConsolidate, spellID = UnitAura(unit, n, filter)
|
local spellName, texture, count, dispelType, duration, expirationTime, unitCaster, _, shouldConsolidate, spellID = UnitAura(unit, n, filter)
|
||||||
if ( not spellID ) then
|
if ( not spellID ) then
|
||||||
Gladdy:SendMessage("AURA_GAIN_LIMIT", unit, auraType, n - 1)
|
Gladdy:SendMessage("AURA_GAIN_LIMIT", unit, auraType, n - 1)
|
||||||
break
|
break
|
||||||
end
|
end
|
||||||
|
if Gladdy.exceptionNames[spellID] then
|
||||||
|
spellName = Gladdy.exceptionNames[spellID]
|
||||||
|
end
|
||||||
|
button.auras[spellID] = { auraType, spellID, spellName, texture, duration, expirationTime, count, dispelType }
|
||||||
if not button.spec and Gladdy.specBuffs[spellName] and unitCaster then
|
if not button.spec and Gladdy.specBuffs[spellName] and unitCaster then
|
||||||
local unitPet = string_gsub(unit, "%d$", "pet%1")
|
local unitPet = string_gsub(unit, "%d$", "pet%1")
|
||||||
if unitCaster and (UnitIsUnit(unit, unitCaster) or UnitIsUnit(unitPet, unitCaster)) then
|
if unitCaster and (UnitIsUnit(unit, unitCaster) or UnitIsUnit(unitPet, unitCaster)) then
|
||||||
@ -305,12 +314,38 @@ function EventListener:UNIT_AURA(unit, isFullUpdate, updatedAuras)
|
|||||||
if Gladdy.cooldownBuffs.racials[spellName] then
|
if Gladdy.cooldownBuffs.racials[spellName] then
|
||||||
Gladdy:SendMessage("RACIAL_USED", unit, spellName, Gladdy.cooldownBuffs.racials[spellName].cd(expirationTime - GetTime()), spellName)
|
Gladdy:SendMessage("RACIAL_USED", unit, spellName, Gladdy.cooldownBuffs.racials[spellName].cd(expirationTime - GetTime()), spellName)
|
||||||
end
|
end
|
||||||
if Gladdy.exceptionNames[spellID] then
|
Gladdy:Debug("INFO", "AURA_GAIN", unit, auraType, spellName)
|
||||||
spellName = Gladdy.exceptionNames[spellID]
|
|
||||||
end
|
|
||||||
Gladdy:SendMessage("AURA_GAIN", unit, auraType, spellID, spellName, texture, duration, expirationTime, count, dispelType, i, unitCaster)
|
Gladdy:SendMessage("AURA_GAIN", unit, auraType, spellID, spellName, texture, duration, expirationTime, count, dispelType, i, unitCaster)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
-- check auras
|
||||||
|
for spellID,v in pairs(button.lastAuras) do
|
||||||
|
if not button.auras[spellID] then
|
||||||
|
if Gladdy.db.cooldown and Cooldowns.cooldownSpellIds[v[3]] then
|
||||||
|
local spellId = Cooldowns.cooldownSpellIds[v[3]] -- don't use spellId from combatlog, in case of different spellrank
|
||||||
|
if spellID == 16188 or spellID == 17116 then -- Nature's Swiftness (same name for druid and shaman)
|
||||||
|
spellId = spellID
|
||||||
|
end
|
||||||
|
--Gladdy:Debug("INFO", "EL:UNIT_AURA Cooldowns:AURA_FADE", unit, spellId)
|
||||||
|
Cooldowns:AURA_FADE(unit, spellId)
|
||||||
|
if spellID == 5384 then -- Feign Death CD Detection needs this
|
||||||
|
Cooldowns:CooldownUsed(unit, Gladdy.buttons[unit].class, 5384)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
wipe(button.lastAuras)
|
||||||
|
button.lastAuras = Gladdy:DeepCopy(button.auras)
|
||||||
|
end
|
||||||
|
|
||||||
|
function EventListener:UpdateAuras(unit)
|
||||||
|
local button = Gladdy.buttons[unit]
|
||||||
|
if not button or button.lastAuras then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
for i=1, #button.lastAuras do
|
||||||
|
Gladdy.modules["Auras"]:AURA_GAIN(unit, unpack(button.lastAuras[i]))
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function EventListener:UNIT_SPELLCAST_START(unit)
|
function EventListener:UNIT_SPELLCAST_START(unit)
|
||||||
@ -338,8 +373,12 @@ function EventListener:UNIT_SPELLCAST_SUCCEEDED(...)
|
|||||||
local unitRace = Gladdy.buttons[unit].race
|
local unitRace = Gladdy.buttons[unit].race
|
||||||
local spellName = GetSpellInfo(spellID)
|
local spellName = GetSpellInfo(spellID)
|
||||||
|
|
||||||
|
if Gladdy.exceptionNames[spellID] then
|
||||||
|
spellName = Gladdy.exceptionNames[spellID]
|
||||||
|
end
|
||||||
|
|
||||||
-- spec detection
|
-- spec detection
|
||||||
if Gladdy.specSpells[spellName] and not Gladdy.buttons[unit].spec then
|
if spellName and Gladdy.specSpells[spellName] and not Gladdy.buttons[unit].spec then
|
||||||
self:DetectSpec(unit, Gladdy.specSpells[spellName])
|
self:DetectSpec(unit, Gladdy.specSpells[spellName])
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -350,10 +389,22 @@ function EventListener:UNIT_SPELLCAST_SUCCEEDED(...)
|
|||||||
end
|
end
|
||||||
|
|
||||||
-- racial
|
-- racial
|
||||||
if Gladdy:Racials()[unitRace].spellName == spellName and Gladdy:Racials()[unitRace][spellID] then
|
if unitRace and Gladdy:Racials()[unitRace].spellName == spellName and Gladdy:Racials()[unitRace][spellID] then
|
||||||
Gladdy:Debug("INFO", "UNIT_SPELLCAST_SUCCEEDED - RACIAL_USED", unit, spellID)
|
Gladdy:Debug("INFO", "UNIT_SPELLCAST_SUCCEEDED - RACIAL_USED", unit, spellID)
|
||||||
Gladdy:SendMessage("RACIAL_USED", unit)
|
Gladdy:SendMessage("RACIAL_USED", unit)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
--cooldown
|
||||||
|
local unitClass
|
||||||
|
if (Gladdy:GetCooldownList()[Gladdy.buttons[unit].class][unit]) then
|
||||||
|
unitClass = Gladdy.buttons[unit].class
|
||||||
|
else
|
||||||
|
unitClass = Gladdy.buttons[unit].race
|
||||||
|
end
|
||||||
|
if spellID ~= 16188 and spellID ~= 17116 and spellID ~= 16166 and spellID ~= 12043 and spellID ~= 5384 then -- Nature's Swiftness CD starts when buff fades
|
||||||
|
Gladdy:Debug("INFO", "UNIT_SPELLCAST_SUCCEEDED", "- CooldownUsed", unit, "spellID:", spellID)
|
||||||
|
Cooldowns:CooldownUsed(unit, unitClass, spellID)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -362,7 +413,7 @@ function EventListener:DetectSpec(unit, spec)
|
|||||||
if (not button or not spec or button.spec) then
|
if (not button or not spec or button.spec) then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
if button.class == "PALADIN" and Gladdy:contains(spec, {L["Holy"], L["Retribution"], L["Protection"]})
|
if button.class == "PALADIN" and not Gladdy:contains(spec, {L["Holy"], L["Retribution"], L["Protection"]})
|
||||||
or button.class == "SHAMAN" and not Gladdy:contains(spec, {L["Restoration"], L["Enhancement"], L["Elemental"]})
|
or button.class == "SHAMAN" and not Gladdy:contains(spec, {L["Restoration"], L["Enhancement"], L["Elemental"]})
|
||||||
or button.class == "ROGUE" and not Gladdy:contains(spec, {L["Subtlety"], L["Assassination"], L["Combat"]})
|
or button.class == "ROGUE" and not Gladdy:contains(spec, {L["Subtlety"], L["Assassination"], L["Combat"]})
|
||||||
or button.class == "WARLOCK" and not Gladdy:contains(spec, {L["Demonology"], L["Destruction"], L["Affliction"]})
|
or button.class == "WARLOCK" and not Gladdy:contains(spec, {L["Demonology"], L["Destruction"], L["Affliction"]})
|
||||||
|
@ -31,6 +31,8 @@ Gladdy.BUTTON_DEFAULTS = {
|
|||||||
stealthed = false,
|
stealthed = false,
|
||||||
classColors = {},
|
classColors = {},
|
||||||
lastState = 0,
|
lastState = 0,
|
||||||
|
auras = {},
|
||||||
|
lastAuras = {}
|
||||||
}
|
}
|
||||||
|
|
||||||
function Gladdy:CreateFrame()
|
function Gladdy:CreateFrame()
|
||||||
|
58
Gladdy.lua
58
Gladdy.lua
@ -13,7 +13,6 @@ local CreateFrame = CreateFrame
|
|||||||
local DEFAULT_CHAT_FRAME = DEFAULT_CHAT_FRAME
|
local DEFAULT_CHAT_FRAME = DEFAULT_CHAT_FRAME
|
||||||
local IsAddOnLoaded = IsAddOnLoaded
|
local IsAddOnLoaded = IsAddOnLoaded
|
||||||
local GetBattlefieldStatus = GetBattlefieldStatus
|
local GetBattlefieldStatus = GetBattlefieldStatus
|
||||||
local IsActiveBattlefieldArena = IsActiveBattlefieldArena
|
|
||||||
local IsInInstance = IsInInstance
|
local IsInInstance = IsInInstance
|
||||||
local GetNumArenaOpponents = GetNumArenaOpponents
|
local GetNumArenaOpponents = GetNumArenaOpponents
|
||||||
local RELEASE_TYPES = { alpha = "Alpha", beta = "Beta", release = "Release"}
|
local RELEASE_TYPES = { alpha = "Alpha", beta = "Beta", release = "Release"}
|
||||||
@ -27,13 +26,13 @@ local LibStub = LibStub
|
|||||||
|
|
||||||
---------------------------
|
---------------------------
|
||||||
|
|
||||||
local MAJOR, MINOR = "Gladdy", 8
|
local MAJOR, MINOR = "Gladdy", 15
|
||||||
local Gladdy = LibStub:NewLibrary(MAJOR, MINOR)
|
local Gladdy = LibStub:NewLibrary(MAJOR, MINOR)
|
||||||
local L
|
local L
|
||||||
Gladdy.version_major_num = 2
|
Gladdy.version_major_num = 2
|
||||||
Gladdy.version_minor_num = 0.20
|
Gladdy.version_minor_num = 0.27
|
||||||
Gladdy.version_num = Gladdy.version_major_num + Gladdy.version_minor_num
|
Gladdy.version_num = Gladdy.version_major_num + Gladdy.version_minor_num
|
||||||
Gladdy.version_releaseType = RELEASE_TYPES.beta
|
Gladdy.version_releaseType = RELEASE_TYPES.release
|
||||||
Gladdy.version = PREFIX .. string.format("%.2f", Gladdy.version_num) .. "-" .. Gladdy.version_releaseType
|
Gladdy.version = PREFIX .. string.format("%.2f", Gladdy.version_num) .. "-" .. Gladdy.version_releaseType
|
||||||
Gladdy.VERSION_REGEX = VERSION_REGEX
|
Gladdy.VERSION_REGEX = VERSION_REGEX
|
||||||
|
|
||||||
@ -433,23 +432,22 @@ end
|
|||||||
function Gladdy:UPDATE_BATTLEFIELD_STATUS(_, index)
|
function Gladdy:UPDATE_BATTLEFIELD_STATUS(_, index)
|
||||||
local status, mapName, instanceID, levelRangeMin, levelRangeMax, teamSize, isRankedArena, suspendedQueue, bool, queueType = GetBattlefieldStatus(index)
|
local status, mapName, instanceID, levelRangeMin, levelRangeMax, teamSize, isRankedArena, suspendedQueue, bool, queueType = GetBattlefieldStatus(index)
|
||||||
local instanceType = select(2, IsInInstance())
|
local instanceType = select(2, IsInInstance())
|
||||||
Gladdy:Debug("INFO", "UPDATE_BATTLEFIELD_STATUS", instanceType, status, teamSize)
|
self:Debug("INFO", "UPDATE_BATTLEFIELD_STATUS", instanceType, status, teamSize)
|
||||||
if ((instanceType == "arena" or GetNumArenaOpponents() > 0) and status == "active" and teamSize > 0) then
|
if ((instanceType == "arena" or GetNumArenaOpponents() > 0) and status == "active" and teamSize > 0) then
|
||||||
self.curBracket = teamSize
|
self.curBracket = teamSize
|
||||||
self:JoinedArena()
|
self:JoinedArena()
|
||||||
|
elseif status == "active" then
|
||||||
|
if self.db.hideBlizzard == "always" then
|
||||||
|
self:BlizzArenaSetAlpha(0)
|
||||||
|
else
|
||||||
|
self:BlizzArenaSetAlpha(1)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function Gladdy:PLAYER_REGEN_ENABLED()
|
function Gladdy:PLAYER_REGEN_ENABLED()
|
||||||
if self.showFrame then
|
if self.showFrame then
|
||||||
self:UpdateFrame()
|
self:InitFrames()
|
||||||
if self.startTest then
|
|
||||||
self:Test()
|
|
||||||
self.startTest = nil
|
|
||||||
end
|
|
||||||
self.frame:Show()
|
|
||||||
self:SendMessage("JOINED_ARENA")
|
|
||||||
self.showFrame = nil
|
|
||||||
end
|
end
|
||||||
if self.hideFrame then
|
if self.hideFrame then
|
||||||
self:Reset()
|
self:Reset()
|
||||||
@ -481,8 +479,8 @@ function Gladdy:Reset()
|
|||||||
for unit in pairs(self.buttons) do
|
for unit in pairs(self.buttons) do
|
||||||
self:ResetUnit(unit)
|
self:ResetUnit(unit)
|
||||||
end
|
end
|
||||||
if Gladdy.db.hideBlizzard == "never" or Gladdy.db.hideBlizzard == "arena" then
|
if self.db.hideBlizzard == "never" or self.db.hideBlizzard == "arena" then
|
||||||
Gladdy:BlizzArenaSetAlpha(1)
|
self:BlizzArenaSetAlpha(1)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -525,6 +523,16 @@ end
|
|||||||
---------------------------
|
---------------------------
|
||||||
|
|
||||||
function Gladdy:JoinedArena()
|
function Gladdy:JoinedArena()
|
||||||
|
if InCombatLockdown() then
|
||||||
|
self:Print("Gladdy frames show as soon as you leave combat")
|
||||||
|
self.showFrame = true
|
||||||
|
else
|
||||||
|
self:InitFrames()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function Gladdy:InitFrames()
|
||||||
|
self.showFrame = nil
|
||||||
if not self.curBracket then
|
if not self.curBracket then
|
||||||
self.curBracket = 2
|
self.curBracket = 2
|
||||||
end
|
end
|
||||||
@ -535,19 +543,21 @@ function Gladdy:JoinedArena()
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if InCombatLockdown() then
|
self:UpdateFrame()
|
||||||
Gladdy:Print("Gladdy frames show as soon as you leave combat")
|
if self.startTest then
|
||||||
self.showFrame = true
|
self:Test()
|
||||||
else
|
self.startTest = nil
|
||||||
self:UpdateFrame()
|
|
||||||
self.frame:Show()
|
|
||||||
self:SendMessage("JOINED_ARENA")
|
|
||||||
end
|
end
|
||||||
|
self.frame:Show()
|
||||||
|
self:SendMessage("JOINED_ARENA")
|
||||||
|
|
||||||
for i=1, self.curBracket do
|
for i=1, self.curBracket do
|
||||||
self.buttons["arena" .. i]:SetAlpha(1)
|
self.buttons["arena" .. i]:SetAlpha(1)
|
||||||
end
|
end
|
||||||
if Gladdy.db.hideBlizzard == "arena" or Gladdy.db.hideBlizzard == "always" then
|
if self.db.hideBlizzard == "arena" or self.db.hideBlizzard == "always" then
|
||||||
Gladdy:BlizzArenaSetAlpha(0)
|
self:BlizzArenaSetAlpha(0)
|
||||||
|
else
|
||||||
|
self:BlizzArenaSetAlpha(1)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
## Interface: 20504
|
|
||||||
## Title: Gladdy |cFFFF0000 game client not supported|r
|
## Title: Gladdy |cFFFF0000 game client not supported|r
|
||||||
## Version: @project-version@
|
## Version: 2.27-Release
|
||||||
## Notes: The most powerful arena AddOn for WoW Classic TBC/WotLK
|
## Notes: The most powerful arena AddOn for WoW Classic TBC/WotLK
|
||||||
## Author: XiconQoo, DnB_Junkee, Knall
|
## Author: XiconQoo, DnB_Junkee, Knall
|
||||||
## X-Email: contact me on discord Knall#1751
|
## X-Email: contact me on discord Knall#1751
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
## Interface: 20504
|
## Interface: 20504
|
||||||
## Title: Gladdy - TBC
|
## Title: Gladdy - TBC
|
||||||
## Version: @project-version@
|
## Version: 2.27-Release
|
||||||
## Notes: The most powerful arena AddOn for WoW 2.5.4
|
## Notes: The most powerful arena AddOn for WoW 2.5.4
|
||||||
## Author: XiconQoo, DnB_Junkee, Knall
|
## Author: XiconQoo, DnB_Junkee, Knall
|
||||||
## X-Email: contact me on discord Knall#1751
|
## X-Email: contact me on discord Knall#1751
|
||||||
@ -13,12 +13,12 @@ embeds.xml
|
|||||||
|
|
||||||
Gladdy.lua
|
Gladdy.lua
|
||||||
Lang.lua
|
Lang.lua
|
||||||
|
Util.lua
|
||||||
Frame.lua
|
Frame.lua
|
||||||
Options.lua
|
Options.lua
|
||||||
Constants_shared.lua
|
Constants_shared.lua
|
||||||
Constants_BCC.lua
|
Constants_BCC.lua
|
||||||
ImportStrings.lua
|
ImportStrings.lua
|
||||||
Util.lua
|
|
||||||
|
|
||||||
Modules\Announcements.lua
|
Modules\Announcements.lua
|
||||||
Modules\Healthbar.lua
|
Modules\Healthbar.lua
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
## Interface: 30400
|
## Interface: 30402
|
||||||
## Title: Gladdy - WotLK
|
## Title: Gladdy - WotLK
|
||||||
## Version: @project-version@
|
## Version: 2.27-Release
|
||||||
## Notes: The most powerful arena AddOn for WoW 3.4.0
|
## Notes: The most powerful arena AddOn for WoW 3.4.2
|
||||||
## Author: XiconQoo, DnB_Junkee, Knall
|
## Author: XiconQoo, DnB_Junkee, Knall
|
||||||
## X-Email: contact me on discord Knall#1751
|
## X-Email: contact me on discord Knall#1751
|
||||||
## X-Curse-Project-ID: 482332
|
## X-Curse-Project-ID: 482332
|
||||||
@ -13,12 +13,12 @@ embeds.xml
|
|||||||
|
|
||||||
Gladdy.lua
|
Gladdy.lua
|
||||||
Lang.lua
|
Lang.lua
|
||||||
|
Util.lua
|
||||||
Frame.lua
|
Frame.lua
|
||||||
Options.lua
|
Options.lua
|
||||||
Constants_shared.lua
|
Constants_shared.lua
|
||||||
Constants_Wrath.lua
|
Constants_Wrath.lua
|
||||||
ImportStrings.lua
|
ImportStrings.lua
|
||||||
Util.lua
|
|
||||||
|
|
||||||
Modules\Announcements.lua
|
Modules\Announcements.lua
|
||||||
Modules\Healthbar.lua
|
Modules\Healthbar.lua
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
-- make into AceComm.
|
-- make into AceComm.
|
||||||
-- @class file
|
-- @class file
|
||||||
-- @name AceComm-3.0
|
-- @name AceComm-3.0
|
||||||
-- @release $Id: AceComm-3.0.lua 1202 2019-05-15 23:11:22Z nevcairiel $
|
-- @release $Id: AceComm-3.0.lua 1284 2022-09-25 09:15:30Z nevcairiel $
|
||||||
|
|
||||||
--[[ AceComm-3.0
|
--[[ AceComm-3.0
|
||||||
|
|
||||||
@ -35,10 +35,6 @@ local error, assert = error, assert
|
|||||||
-- WoW APIs
|
-- WoW APIs
|
||||||
local Ambiguate = Ambiguate
|
local Ambiguate = Ambiguate
|
||||||
|
|
||||||
-- Global vars/functions that we don't upvalue since they might get hooked, or upgraded
|
|
||||||
-- List them here for Mikk's FindGlobals script
|
|
||||||
-- GLOBALS: LibStub, DEFAULT_CHAT_FRAME, geterrorhandler, RegisterAddonMessagePrefix
|
|
||||||
|
|
||||||
AceComm.embeds = AceComm.embeds or {}
|
AceComm.embeds = AceComm.embeds or {}
|
||||||
|
|
||||||
-- for my sanity and yours, let's give the message type bytes some names
|
-- for my sanity and yours, let's give the message type bytes some names
|
||||||
|
@ -75,7 +75,7 @@ local next = next
|
|||||||
local strlen = string.len
|
local strlen = string.len
|
||||||
local GetFramerate = GetFramerate
|
local GetFramerate = GetFramerate
|
||||||
local strlower = string.lower
|
local strlower = string.lower
|
||||||
local unpack,type,pairs,wipe = unpack,type,pairs,wipe
|
local unpack,type,pairs,wipe = unpack,type,pairs,table.wipe
|
||||||
local UnitInRaid,UnitInParty = UnitInRaid,UnitInParty
|
local UnitInRaid,UnitInParty = UnitInRaid,UnitInParty
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
--- AceConfigCmd-3.0 handles access to an options table through the "command line" interface via the ChatFrames.
|
--- AceConfigCmd-3.0 handles access to an options table through the "command line" interface via the ChatFrames.
|
||||||
-- @class file
|
-- @class file
|
||||||
-- @name AceConfigCmd-3.0
|
-- @name AceConfigCmd-3.0
|
||||||
-- @release $Id: AceConfigCmd-3.0.lua 1202 2019-05-15 23:11:22Z nevcairiel $
|
-- @release $Id: AceConfigCmd-3.0.lua 1284 2022-09-25 09:15:30Z nevcairiel $
|
||||||
|
|
||||||
--[[
|
--[[
|
||||||
AceConfigCmd-3.0
|
AceConfigCmd-3.0
|
||||||
@ -37,17 +37,10 @@ local error, assert = error, assert
|
|||||||
-- WoW APIs
|
-- WoW APIs
|
||||||
local _G = _G
|
local _G = _G
|
||||||
|
|
||||||
-- Global vars/functions that we don't upvalue since they might get hooked, or upgraded
|
|
||||||
-- List them here for Mikk's FindGlobals script
|
|
||||||
-- GLOBALS: LibStub, SELECTED_CHAT_FRAME, DEFAULT_CHAT_FRAME
|
|
||||||
|
|
||||||
|
|
||||||
local L = setmetatable({}, { -- TODO: replace with proper locale
|
local L = setmetatable({}, { -- TODO: replace with proper locale
|
||||||
__index = function(self,k) return k end
|
__index = function(self,k) return k end
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
local function print(msg)
|
local function print(msg)
|
||||||
(SELECTED_CHAT_FRAME or DEFAULT_CHAT_FRAME):AddMessage(msg)
|
(SELECTED_CHAT_FRAME or DEFAULT_CHAT_FRAME):AddMessage(msg)
|
||||||
end
|
end
|
||||||
@ -401,7 +394,7 @@ local function handle(info, inputpos, tab, depth, retfalse)
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
local str = strsub(info.input,inputpos);
|
local strInput = strsub(info.input,inputpos);
|
||||||
|
|
||||||
if tab.type=="execute" then
|
if tab.type=="execute" then
|
||||||
------------ execute --------------------------------------------
|
------------ execute --------------------------------------------
|
||||||
@ -414,21 +407,21 @@ local function handle(info, inputpos, tab, depth, retfalse)
|
|||||||
|
|
||||||
local res = true
|
local res = true
|
||||||
if tab.pattern then
|
if tab.pattern then
|
||||||
if not(type(tab.pattern)=="string") then err(info, inputpos, "'pattern' - expected a string") end
|
if type(tab.pattern)~="string" then err(info, inputpos, "'pattern' - expected a string") end
|
||||||
if not strmatch(str, tab.pattern) then
|
if not strmatch(strInput, tab.pattern) then
|
||||||
usererr(info, inputpos, "'"..str.."' - " .. L["invalid input"])
|
usererr(info, inputpos, "'"..strInput.."' - " .. L["invalid input"])
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
do_final(info, inputpos, tab, "set", str)
|
do_final(info, inputpos, tab, "set", strInput)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
elseif tab.type=="toggle" then
|
elseif tab.type=="toggle" then
|
||||||
------------ toggle --------------------------------------------
|
------------ toggle --------------------------------------------
|
||||||
local b
|
local b
|
||||||
local str = strtrim(strlower(str))
|
local str = strtrim(strlower(strInput))
|
||||||
if str=="" then
|
if str=="" then
|
||||||
b = callmethod(info, inputpos, tab, "get")
|
b = callmethod(info, inputpos, tab, "get")
|
||||||
|
|
||||||
@ -465,9 +458,9 @@ local function handle(info, inputpos, tab, depth, retfalse)
|
|||||||
|
|
||||||
elseif tab.type=="range" then
|
elseif tab.type=="range" then
|
||||||
------------ range --------------------------------------------
|
------------ range --------------------------------------------
|
||||||
local val = tonumber(str)
|
local val = tonumber(strInput)
|
||||||
if not val then
|
if not val then
|
||||||
usererr(info, inputpos, "'"..str.."' - "..L["expected number"])
|
usererr(info, inputpos, "'"..strInput.."' - "..L["expected number"])
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
if type(info.step)=="number" then
|
if type(info.step)=="number" then
|
||||||
@ -487,7 +480,7 @@ local function handle(info, inputpos, tab, depth, retfalse)
|
|||||||
|
|
||||||
elseif tab.type=="select" then
|
elseif tab.type=="select" then
|
||||||
------------ select ------------------------------------
|
------------ select ------------------------------------
|
||||||
local str = strtrim(strlower(str))
|
local str = strtrim(strlower(strInput))
|
||||||
|
|
||||||
local values = tab.values
|
local values = tab.values
|
||||||
if type(values) == "function" or type(values) == "string" then
|
if type(values) == "function" or type(values) == "string" then
|
||||||
@ -528,7 +521,7 @@ local function handle(info, inputpos, tab, depth, retfalse)
|
|||||||
|
|
||||||
elseif tab.type=="multiselect" then
|
elseif tab.type=="multiselect" then
|
||||||
------------ multiselect -------------------------------------------
|
------------ multiselect -------------------------------------------
|
||||||
local str = strtrim(strlower(str))
|
local str = strtrim(strlower(strInput))
|
||||||
|
|
||||||
local values = tab.values
|
local values = tab.values
|
||||||
if type(values) == "function" or type(values) == "string" then
|
if type(values) == "function" or type(values) == "string" then
|
||||||
@ -565,7 +558,7 @@ local function handle(info, inputpos, tab, depth, retfalse)
|
|||||||
|
|
||||||
--check that the opt is valid
|
--check that the opt is valid
|
||||||
local ok
|
local ok
|
||||||
for k,v in pairs(values) do
|
for k in pairs(values) do
|
||||||
if strlower(k)==opt then
|
if strlower(k)==opt then
|
||||||
opt = k -- overwrite with key (in case of case mismatches)
|
opt = k -- overwrite with key (in case of case mismatches)
|
||||||
ok = true
|
ok = true
|
||||||
@ -634,7 +627,7 @@ local function handle(info, inputpos, tab, depth, retfalse)
|
|||||||
|
|
||||||
elseif tab.type=="color" then
|
elseif tab.type=="color" then
|
||||||
------------ color --------------------------------------------
|
------------ color --------------------------------------------
|
||||||
local str = strtrim(strlower(str))
|
local str = strtrim(strlower(strInput))
|
||||||
if str == "" then
|
if str == "" then
|
||||||
--TODO: Show current value
|
--TODO: Show current value
|
||||||
return
|
return
|
||||||
@ -706,7 +699,7 @@ local function handle(info, inputpos, tab, depth, retfalse)
|
|||||||
|
|
||||||
elseif tab.type=="keybinding" then
|
elseif tab.type=="keybinding" then
|
||||||
------------ keybinding --------------------------------------------
|
------------ keybinding --------------------------------------------
|
||||||
local str = strtrim(strlower(str))
|
local str = strtrim(strlower(strInput))
|
||||||
if str == "" then
|
if str == "" then
|
||||||
--TODO: Show current value
|
--TODO: Show current value
|
||||||
return
|
return
|
||||||
|
@ -1,13 +1,13 @@
|
|||||||
--- AceConfigDialog-3.0 generates AceGUI-3.0 based windows based on option tables.
|
--- AceConfigDialog-3.0 generates AceGUI-3.0 based windows based on option tables.
|
||||||
-- @class file
|
-- @class file
|
||||||
-- @name AceConfigDialog-3.0
|
-- @name AceConfigDialog-3.0
|
||||||
-- @release $Id: AceConfigDialog-3.0.lua 1232 2020-04-14 22:21:22Z nevcairiel $
|
-- @release $Id: AceConfigDialog-3.0.lua 1296 2022-11-04 18:50:10Z nevcairiel $
|
||||||
|
|
||||||
local LibStub = LibStub
|
local LibStub = LibStub
|
||||||
local gui = LibStub("AceGUI-3.0")
|
local gui = LibStub("AceGUI-3.0")
|
||||||
local reg = LibStub("AceConfigRegistry-3.0")
|
local reg = LibStub("AceConfigRegistry-3.0")
|
||||||
|
|
||||||
local MAJOR, MINOR = "AceConfigDialog-3.0", 79
|
local MAJOR, MINOR = "AceConfigDialog-3.0", 86
|
||||||
local AceConfigDialog, oldminor = LibStub:NewLibrary(MAJOR, MINOR)
|
local AceConfigDialog, oldminor = LibStub:NewLibrary(MAJOR, MINOR)
|
||||||
|
|
||||||
if not AceConfigDialog then return end
|
if not AceConfigDialog then return end
|
||||||
@ -22,19 +22,13 @@ AceConfigDialog.frame.closing = AceConfigDialog.frame.closing or {}
|
|||||||
AceConfigDialog.frame.closeAllOverride = AceConfigDialog.frame.closeAllOverride or {}
|
AceConfigDialog.frame.closeAllOverride = AceConfigDialog.frame.closeAllOverride or {}
|
||||||
|
|
||||||
-- Lua APIs
|
-- Lua APIs
|
||||||
local tinsert, tsort, tremove = table.insert, table.sort, table.remove
|
local tinsert, tsort, tremove, wipe = table.insert, table.sort, table.remove, table.wipe
|
||||||
local strmatch, format = string.match, string.format
|
local strmatch, format = string.match, string.format
|
||||||
local error = error
|
local error = error
|
||||||
local pairs, next, select, type, unpack, wipe, ipairs = pairs, next, select, type, unpack, wipe, ipairs
|
local pairs, next, select, type, unpack, ipairs = pairs, next, select, type, unpack, ipairs
|
||||||
local tostring, tonumber = tostring, tonumber
|
local tostring, tonumber = tostring, tonumber
|
||||||
local math_min, math_max, math_floor = math.min, math.max, math.floor
|
local math_min, math_max, math_floor = math.min, math.max, math.floor
|
||||||
|
|
||||||
-- Global vars/functions that we don't upvalue since they might get hooked, or upgraded
|
|
||||||
-- List them here for Mikk's FindGlobals script
|
|
||||||
-- GLOBALS: NORMAL_FONT_COLOR, ACCEPT, CANCEL
|
|
||||||
-- GLOBALS: PlaySound, GameFontHighlight, GameFontHighlightSmall, GameFontHighlightLarge
|
|
||||||
-- GLOBALS: CloseSpecialWindows, InterfaceOptions_AddCategory, geterrorhandler
|
|
||||||
|
|
||||||
local emptyTbl = {}
|
local emptyTbl = {}
|
||||||
|
|
||||||
--[[
|
--[[
|
||||||
@ -153,6 +147,7 @@ local stringIsLiteral = {
|
|||||||
width = true,
|
width = true,
|
||||||
image = true,
|
image = true,
|
||||||
fontSize = true,
|
fontSize = true,
|
||||||
|
tooltipHyperlink = true
|
||||||
}
|
}
|
||||||
|
|
||||||
--Is Never a function or method
|
--Is Never a function or method
|
||||||
@ -194,9 +189,8 @@ local function GetOptionsMemberValue(membername, option, options, path, appName,
|
|||||||
--We have a function to call
|
--We have a function to call
|
||||||
local info = new()
|
local info = new()
|
||||||
--traverse the options table, picking up the handler and filling the info with the path
|
--traverse the options table, picking up the handler and filling the info with the path
|
||||||
local handler
|
|
||||||
local group = options
|
local group = options
|
||||||
handler = group.handler or handler
|
local handler = group.handler
|
||||||
|
|
||||||
for i = 1, #path do
|
for i = 1, #path do
|
||||||
group = GetSubOption(group, path[i])
|
group = GetSubOption(group, path[i])
|
||||||
@ -508,6 +502,14 @@ local function OptionOnMouseOver(widget, event)
|
|||||||
local tooltip = AceConfigDialog.tooltip
|
local tooltip = AceConfigDialog.tooltip
|
||||||
|
|
||||||
tooltip:SetOwner(widget.frame, "ANCHOR_TOPRIGHT")
|
tooltip:SetOwner(widget.frame, "ANCHOR_TOPRIGHT")
|
||||||
|
|
||||||
|
local tooltipHyperlink = GetOptionsMemberValue("tooltipHyperlink", opt, options, path, appName)
|
||||||
|
if tooltipHyperlink then
|
||||||
|
tooltip:SetHyperlink(tooltipHyperlink)
|
||||||
|
tooltip:Show()
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
local name = GetOptionsMemberValue("name", opt, options, path, appName)
|
local name = GetOptionsMemberValue("name", opt, options, path, appName)
|
||||||
local desc = GetOptionsMemberValue("desc", opt, options, path, appName)
|
local desc = GetOptionsMemberValue("desc", opt, options, path, appName)
|
||||||
local usage = GetOptionsMemberValue("usage", opt, options, path, appName)
|
local usage = GetOptionsMemberValue("usage", opt, options, path, appName)
|
||||||
@ -535,8 +537,7 @@ local function OptionOnMouseLeave(widget, event)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function GetFuncName(option)
|
local function GetFuncName(option)
|
||||||
local type = option.type
|
if option.type == "execute" then
|
||||||
if type == "execute" then
|
|
||||||
return "func"
|
return "func"
|
||||||
else
|
else
|
||||||
return "set"
|
return "set"
|
||||||
@ -544,13 +545,15 @@ local function GetFuncName(option)
|
|||||||
end
|
end
|
||||||
do
|
do
|
||||||
local frame = AceConfigDialog.popup
|
local frame = AceConfigDialog.popup
|
||||||
if not frame then
|
if not frame or oldminor < 81 then
|
||||||
frame = CreateFrame("Frame", nil, UIParent)
|
frame = CreateFrame("Frame", nil, UIParent)
|
||||||
AceConfigDialog.popup = frame
|
AceConfigDialog.popup = frame
|
||||||
frame:Hide()
|
frame:Hide()
|
||||||
frame:SetPoint("CENTER", UIParent, "CENTER")
|
frame:SetPoint("CENTER", UIParent, "CENTER")
|
||||||
frame:SetSize(320, 72)
|
frame:SetSize(320, 72)
|
||||||
|
frame:EnableMouse(true) -- Do not allow click-through on the frame
|
||||||
frame:SetFrameStrata("TOOLTIP")
|
frame:SetFrameStrata("TOOLTIP")
|
||||||
|
frame:SetFrameLevel(100) -- Lots of room to draw under it
|
||||||
frame:SetScript("OnKeyDown", function(self, key)
|
frame:SetScript("OnKeyDown", function(self, key)
|
||||||
if key == "ESCAPE" then
|
if key == "ESCAPE" then
|
||||||
self:SetPropagateKeyboardInput(false)
|
self:SetPropagateKeyboardInput(false)
|
||||||
@ -564,26 +567,17 @@ do
|
|||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
|
|
||||||
if WOW_PROJECT_ID == WOW_PROJECT_CLASSIC then
|
local border = CreateFrame("Frame", nil, frame, "DialogBorderOpaqueTemplate")
|
||||||
frame:SetBackdrop({
|
border:SetAllPoints(frame)
|
||||||
bgFile = [[Interface\DialogFrame\UI-DialogBox-Background-Dark]],
|
frame:SetFixedFrameStrata(true)
|
||||||
edgeFile = [[Interface\DialogFrame\UI-DialogBox-Border]],
|
frame:SetFixedFrameLevel(true)
|
||||||
tile = true,
|
|
||||||
tileSize = 32,
|
|
||||||
edgeSize = 32,
|
|
||||||
insets = { left = 11, right = 11, top = 11, bottom = 11 },
|
|
||||||
})
|
|
||||||
else
|
|
||||||
local border = CreateFrame("Frame", nil, frame, "DialogBorderDarkTemplate")
|
|
||||||
border:SetAllPoints(frame)
|
|
||||||
end
|
|
||||||
|
|
||||||
local text = frame:CreateFontString(nil, "ARTWORK", "GameFontHighlight")
|
local text = frame:CreateFontString(nil, "ARTWORK", "GameFontHighlight")
|
||||||
text:SetSize(290, 0)
|
text:SetSize(290, 0)
|
||||||
text:SetPoint("TOP", 0, -16)
|
text:SetPoint("TOP", 0, -16)
|
||||||
frame.text = text
|
frame.text = text
|
||||||
|
|
||||||
local function newButton(text)
|
local function newButton(newText)
|
||||||
local button = CreateFrame("Button", nil, frame)
|
local button = CreateFrame("Button", nil, frame)
|
||||||
button:SetSize(128, 21)
|
button:SetSize(128, 21)
|
||||||
button:SetNormalFontObject(GameFontNormal)
|
button:SetNormalFontObject(GameFontNormal)
|
||||||
@ -594,7 +588,7 @@ do
|
|||||||
button:GetPushedTexture():SetTexCoord(0.0, 1.0, 0.0, 0.71875)
|
button:GetPushedTexture():SetTexCoord(0.0, 1.0, 0.0, 0.71875)
|
||||||
button:SetHighlightTexture(130762) -- "Interface\\Buttons\\UI-DialogBox-Button-Highlight"
|
button:SetHighlightTexture(130762) -- "Interface\\Buttons\\UI-DialogBox-Button-Highlight"
|
||||||
button:GetHighlightTexture():SetTexCoord(0.0, 1.0, 0.0, 0.71875)
|
button:GetHighlightTexture():SetTexCoord(0.0, 1.0, 0.0, 0.71875)
|
||||||
button:SetText(text)
|
button:SetText(newText)
|
||||||
return button
|
return button
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -681,7 +675,7 @@ local function ActivateControl(widget, event, ...)
|
|||||||
if group[funcname] ~= nil then
|
if group[funcname] ~= nil then
|
||||||
func = group[funcname]
|
func = group[funcname]
|
||||||
end
|
end
|
||||||
handler = group.handler or handler
|
handler = group.handler
|
||||||
confirm = group.confirm
|
confirm = group.confirm
|
||||||
validate = group.validate
|
validate = group.validate
|
||||||
for i = 1, #path do
|
for i = 1, #path do
|
||||||
@ -745,7 +739,6 @@ local function ActivateControl(widget, event, ...)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local rootframe = user.rootframe
|
|
||||||
if not validated or type(validated) == "string" then
|
if not validated or type(validated) == "string" then
|
||||||
if not validated then
|
if not validated then
|
||||||
if usage then
|
if usage then
|
||||||
@ -760,8 +753,8 @@ local function ActivateControl(widget, event, ...)
|
|||||||
end
|
end
|
||||||
|
|
||||||
-- show validate message
|
-- show validate message
|
||||||
if rootframe.SetStatusText then
|
if user.rootframe.SetStatusText then
|
||||||
rootframe:SetStatusText(validated)
|
user.rootframe:SetStatusText(validated)
|
||||||
else
|
else
|
||||||
validationErrorPopup(validated)
|
validationErrorPopup(validated)
|
||||||
end
|
end
|
||||||
@ -798,14 +791,14 @@ local function ActivateControl(widget, event, ...)
|
|||||||
if type(confirm) == "boolean" then
|
if type(confirm) == "boolean" then
|
||||||
if confirm then
|
if confirm then
|
||||||
if not confirmText then
|
if not confirmText then
|
||||||
local name, desc = option.name, option.desc
|
local option_name, desc = option.name, option.desc
|
||||||
if type(name) == "function" then
|
if type(option_name) == "function" then
|
||||||
name = name(info)
|
option_name = option_name(info)
|
||||||
end
|
end
|
||||||
if type(desc) == "function" then
|
if type(desc) == "function" then
|
||||||
desc = desc(info)
|
desc = desc(info)
|
||||||
end
|
end
|
||||||
confirmText = name
|
confirmText = option_name
|
||||||
if desc then
|
if desc then
|
||||||
confirmText = confirmText.." - "..desc
|
confirmText = confirmText.." - "..desc
|
||||||
end
|
end
|
||||||
@ -1147,8 +1140,6 @@ local function FeedOptions(appName, options,container,rootframe,path,group,inlin
|
|||||||
--Control to feed
|
--Control to feed
|
||||||
local control
|
local control
|
||||||
|
|
||||||
local name = GetOptionsMemberValue("name", v, options, path, appName)
|
|
||||||
|
|
||||||
if v.type == "execute" then
|
if v.type == "execute" then
|
||||||
|
|
||||||
local imageCoords = GetOptionsMemberValue("imageCoords",v, options, path, appName)
|
local imageCoords = GetOptionsMemberValue("imageCoords",v, options, path, appName)
|
||||||
@ -1251,7 +1242,7 @@ local function FeedOptions(appName, options,container,rootframe,path,group,inlin
|
|||||||
end
|
end
|
||||||
tsort(sorting, sortTblAsStrings)
|
tsort(sorting, sortTblAsStrings)
|
||||||
end
|
end
|
||||||
for k, value in ipairs(sorting) do
|
for _, value in ipairs(sorting) do
|
||||||
local text = values[value]
|
local text = values[value]
|
||||||
local radio = gui:Create("CheckBox")
|
local radio = gui:Create("CheckBox")
|
||||||
radio:SetLabel(text)
|
radio:SetLabel(text)
|
||||||
@ -1333,8 +1324,8 @@ local function FeedOptions(appName, options,container,rootframe,path,group,inlin
|
|||||||
control:SetWidth(width_multiplier)
|
control:SetWidth(width_multiplier)
|
||||||
end
|
end
|
||||||
--check:SetTriState(v.tristate)
|
--check:SetTriState(v.tristate)
|
||||||
for i = 1, #valuesort do
|
for s = 1, #valuesort do
|
||||||
local key = valuesort[i]
|
local key = valuesort[s]
|
||||||
local value = GetOptionsMemberValue("get",v, options, path, appName, key)
|
local value = GetOptionsMemberValue("get",v, options, path, appName, key)
|
||||||
control:SetItemValue(key,value)
|
control:SetItemValue(key,value)
|
||||||
end
|
end
|
||||||
@ -1346,8 +1337,8 @@ local function FeedOptions(appName, options,container,rootframe,path,group,inlin
|
|||||||
|
|
||||||
control:PauseLayout()
|
control:PauseLayout()
|
||||||
local width = GetOptionsMemberValue("width",v,options,path,appName)
|
local width = GetOptionsMemberValue("width",v,options,path,appName)
|
||||||
for i = 1, #valuesort do
|
for s = 1, #valuesort do
|
||||||
local value = valuesort[i]
|
local value = valuesort[s]
|
||||||
local text = values[value]
|
local text = values[value]
|
||||||
local check = gui:Create("CheckBox")
|
local check = gui:Create("CheckBox")
|
||||||
check:SetLabel(text)
|
check:SetLabel(text)
|
||||||
@ -1364,7 +1355,7 @@ local function FeedOptions(appName, options,container,rootframe,path,group,inlin
|
|||||||
elseif width == "half" then
|
elseif width == "half" then
|
||||||
check:SetWidth(width_multiplier / 2)
|
check:SetWidth(width_multiplier / 2)
|
||||||
elseif (type(width) == "number") then
|
elseif (type(width) == "number") then
|
||||||
control:SetWidth(width_multiplier * width)
|
check:SetWidth(width_multiplier * width)
|
||||||
elseif width == "full" then
|
elseif width == "full" then
|
||||||
check.width = "fill"
|
check.width = "fill"
|
||||||
else
|
else
|
||||||
@ -1434,8 +1425,8 @@ local function FeedOptions(appName, options,container,rootframe,path,group,inlin
|
|||||||
end
|
end
|
||||||
control:SetImageSize(width, height)
|
control:SetImageSize(width, height)
|
||||||
end
|
end
|
||||||
local width = GetOptionsMemberValue("width",v,options,path,appName)
|
local controlWidth = GetOptionsMemberValue("width",v,options,path,appName)
|
||||||
control.width = not width and "fill"
|
control.width = not controlWidth and "fill"
|
||||||
end
|
end
|
||||||
|
|
||||||
--Common Init
|
--Common Init
|
||||||
@ -1690,29 +1681,29 @@ function AceConfigDialog:FeedGroup(appName,options,container,rootframe,path, isR
|
|||||||
|
|
||||||
elseif grouptype == "select" then
|
elseif grouptype == "select" then
|
||||||
|
|
||||||
local select = gui:Create("DropdownGroup")
|
local selectGroup = gui:Create("DropdownGroup")
|
||||||
select:SetTitle(name)
|
selectGroup:SetTitle(name)
|
||||||
InjectInfo(select, options, group, path, rootframe, appName)
|
InjectInfo(selectGroup, options, group, path, rootframe, appName)
|
||||||
select:SetCallback("OnGroupSelected", GroupSelected)
|
selectGroup:SetCallback("OnGroupSelected", GroupSelected)
|
||||||
local status = AceConfigDialog:GetStatusTable(appName, path)
|
local status = AceConfigDialog:GetStatusTable(appName, path)
|
||||||
if not status.groups then
|
if not status.groups then
|
||||||
status.groups = {}
|
status.groups = {}
|
||||||
end
|
end
|
||||||
select:SetStatusTable(status.groups)
|
selectGroup:SetStatusTable(status.groups)
|
||||||
local grouplist, orderlist = BuildSelect(group, options, path, appName)
|
local grouplist, orderlist = BuildSelect(group, options, path, appName)
|
||||||
select:SetGroupList(grouplist, orderlist)
|
selectGroup:SetGroupList(grouplist, orderlist)
|
||||||
select:SetUserData("grouplist", grouplist)
|
selectGroup:SetUserData("grouplist", grouplist)
|
||||||
select:SetUserData("orderlist", orderlist)
|
selectGroup:SetUserData("orderlist", orderlist)
|
||||||
|
|
||||||
local firstgroup = orderlist[1]
|
local firstgroup = orderlist[1]
|
||||||
if firstgroup then
|
if firstgroup then
|
||||||
select:SetGroup((GroupExists(appName, options, path,status.groups.selected) and status.groups.selected) or firstgroup)
|
selectGroup:SetGroup((GroupExists(appName, options, path,status.groups.selected) and status.groups.selected) or firstgroup)
|
||||||
end
|
end
|
||||||
|
|
||||||
select.width = "fill"
|
selectGroup.width = "fill"
|
||||||
select.height = "fill"
|
selectGroup.height = "fill"
|
||||||
|
|
||||||
container:AddChild(select)
|
container:AddChild(selectGroup)
|
||||||
|
|
||||||
--assume tree group by default
|
--assume tree group by default
|
||||||
--if parenttype is tree then this group is already a node on that tree
|
--if parenttype is tree then this group is already a node on that tree
|
||||||
@ -1940,13 +1931,13 @@ end
|
|||||||
-- convert pre-39 BlizOptions structure to the new format
|
-- convert pre-39 BlizOptions structure to the new format
|
||||||
if oldminor and oldminor < 39 and AceConfigDialog.BlizOptions then
|
if oldminor and oldminor < 39 and AceConfigDialog.BlizOptions then
|
||||||
local old = AceConfigDialog.BlizOptions
|
local old = AceConfigDialog.BlizOptions
|
||||||
local new = {}
|
local newOpt = {}
|
||||||
for key, widget in pairs(old) do
|
for key, widget in pairs(old) do
|
||||||
local appName = widget:GetUserData("appName")
|
local appName = widget:GetUserData("appName")
|
||||||
if not new[appName] then new[appName] = {} end
|
if not newOpt[appName] then newOpt[appName] = {} end
|
||||||
new[appName][key] = widget
|
newOpt[appName][key] = widget
|
||||||
end
|
end
|
||||||
AceConfigDialog.BlizOptions = new
|
AceConfigDialog.BlizOptions = newOpt
|
||||||
else
|
else
|
||||||
AceConfigDialog.BlizOptions = AceConfigDialog.BlizOptions or {}
|
AceConfigDialog.BlizOptions = AceConfigDialog.BlizOptions or {}
|
||||||
end
|
end
|
||||||
@ -1979,6 +1970,7 @@ end
|
|||||||
-- @param parent The parent to use in the interface options tree.
|
-- @param parent The parent to use in the interface options tree.
|
||||||
-- @param ... The path in the options table to feed into the interface options panel.
|
-- @param ... The path in the options table to feed into the interface options panel.
|
||||||
-- @return The reference to the frame registered into the Interface Options.
|
-- @return The reference to the frame registered into the Interface Options.
|
||||||
|
-- @return The category ID to pass to Settings.OpenToCategory (or InterfaceOptionsFrame_OpenToCategory)
|
||||||
function AceConfigDialog:AddToBlizOptions(appName, name, parent, ...)
|
function AceConfigDialog:AddToBlizOptions(appName, name, parent, ...)
|
||||||
local BlizOptions = AceConfigDialog.BlizOptions
|
local BlizOptions = AceConfigDialog.BlizOptions
|
||||||
|
|
||||||
@ -1994,7 +1986,6 @@ function AceConfigDialog:AddToBlizOptions(appName, name, parent, ...)
|
|||||||
if not BlizOptions[appName][key] then
|
if not BlizOptions[appName][key] then
|
||||||
local group = gui:Create("BlizOptionsGroup")
|
local group = gui:Create("BlizOptionsGroup")
|
||||||
BlizOptions[appName][key] = group
|
BlizOptions[appName][key] = group
|
||||||
group:SetName(name or appName, parent)
|
|
||||||
|
|
||||||
group:SetTitle(name or appName)
|
group:SetTitle(name or appName)
|
||||||
group:SetUserData("appName", appName)
|
group:SetUserData("appName", appName)
|
||||||
@ -2007,8 +1998,30 @@ function AceConfigDialog:AddToBlizOptions(appName, name, parent, ...)
|
|||||||
end
|
end
|
||||||
group:SetCallback("OnShow", FeedToBlizPanel)
|
group:SetCallback("OnShow", FeedToBlizPanel)
|
||||||
group:SetCallback("OnHide", ClearBlizPanel)
|
group:SetCallback("OnHide", ClearBlizPanel)
|
||||||
InterfaceOptions_AddCategory(group.frame)
|
if Settings and Settings.RegisterCanvasLayoutCategory then
|
||||||
return group.frame
|
local categoryName = name or appName
|
||||||
|
if parent then
|
||||||
|
local category = Settings.GetCategory(parent)
|
||||||
|
if not category then
|
||||||
|
error(("The parent category '%s' was not found"):format(parent), 2)
|
||||||
|
end
|
||||||
|
local subcategory = Settings.RegisterCanvasLayoutSubcategory(category, group.frame, categoryName)
|
||||||
|
|
||||||
|
-- force the generated ID to be used for subcategories, as these can have very simple names like "Profiles"
|
||||||
|
group:SetName(subcategory.ID, parent)
|
||||||
|
else
|
||||||
|
local category = Settings.RegisterCanvasLayoutCategory(group.frame, categoryName)
|
||||||
|
-- using appName here would be cleaner, but would not be 100% compatible
|
||||||
|
-- but for top-level categories it should be fine, as these are typically addon names
|
||||||
|
category.ID = categoryName
|
||||||
|
group:SetName(categoryName, parent)
|
||||||
|
Settings.RegisterAddOnCategory(category)
|
||||||
|
end
|
||||||
|
else
|
||||||
|
group:SetName(name or appName, parent)
|
||||||
|
InterfaceOptions_AddCategory(group.frame)
|
||||||
|
end
|
||||||
|
return group.frame, group.frame.name
|
||||||
else
|
else
|
||||||
error(("%s has already been added to the Blizzard Options Window with the given path"):format(appName), 2)
|
error(("%s has already been added to the Blizzard Options Window with the given path"):format(appName), 2)
|
||||||
end
|
end
|
||||||
|
@ -8,10 +8,10 @@
|
|||||||
-- :IterateOptionsTables() (and :GetOptionsTable() if only given one argument) return a function reference that the requesting config handling addon must call with valid "uiType", "uiName".
|
-- :IterateOptionsTables() (and :GetOptionsTable() if only given one argument) return a function reference that the requesting config handling addon must call with valid "uiType", "uiName".
|
||||||
-- @class file
|
-- @class file
|
||||||
-- @name AceConfigRegistry-3.0
|
-- @name AceConfigRegistry-3.0
|
||||||
-- @release $Id: AceConfigRegistry-3.0.lua 1207 2019-06-23 12:08:33Z nevcairiel $
|
-- @release $Id: AceConfigRegistry-3.0.lua 1296 2022-11-04 18:50:10Z nevcairiel $
|
||||||
local CallbackHandler = LibStub("CallbackHandler-1.0")
|
local CallbackHandler = LibStub("CallbackHandler-1.0")
|
||||||
|
|
||||||
local MAJOR, MINOR = "AceConfigRegistry-3.0", 20
|
local MAJOR, MINOR = "AceConfigRegistry-3.0", 21
|
||||||
local AceConfigRegistry = LibStub:NewLibrary(MAJOR, MINOR)
|
local AceConfigRegistry = LibStub:NewLibrary(MAJOR, MINOR)
|
||||||
|
|
||||||
if not AceConfigRegistry then return end
|
if not AceConfigRegistry then return end
|
||||||
@ -83,6 +83,7 @@ local basekeys={
|
|||||||
dialogHidden=optmethodbool,
|
dialogHidden=optmethodbool,
|
||||||
dropdownHidden=optmethodbool,
|
dropdownHidden=optmethodbool,
|
||||||
cmdHidden=optmethodbool,
|
cmdHidden=optmethodbool,
|
||||||
|
tooltipHyperlink=optstringfunc,
|
||||||
icon=optstringnumberfunc,
|
icon=optstringnumberfunc,
|
||||||
iconCoords=optmethodtable,
|
iconCoords=optmethodtable,
|
||||||
handler=opttable,
|
handler=opttable,
|
||||||
|
@ -40,8 +40,8 @@
|
|||||||
-- end
|
-- end
|
||||||
-- @class file
|
-- @class file
|
||||||
-- @name AceDB-3.0.lua
|
-- @name AceDB-3.0.lua
|
||||||
-- @release $Id: AceDB-3.0.lua 1217 2019-07-11 03:06:18Z funkydude $
|
-- @release $Id: AceDB-3.0.lua 1306 2023-06-23 14:55:09Z nevcairiel $
|
||||||
local ACEDB_MAJOR, ACEDB_MINOR = "AceDB-3.0", 27
|
local ACEDB_MAJOR, ACEDB_MINOR = "AceDB-3.0", 28
|
||||||
local AceDB = LibStub:NewLibrary(ACEDB_MAJOR, ACEDB_MINOR)
|
local AceDB = LibStub:NewLibrary(ACEDB_MAJOR, ACEDB_MINOR)
|
||||||
|
|
||||||
if not AceDB then return end -- No upgrade needed
|
if not AceDB then return end -- No upgrade needed
|
||||||
@ -53,10 +53,6 @@ local setmetatable, rawset, rawget = setmetatable, rawset, rawget
|
|||||||
-- WoW APIs
|
-- WoW APIs
|
||||||
local _G = _G
|
local _G = _G
|
||||||
|
|
||||||
-- Global vars/functions that we don't upvalue since they might get hooked, or upgraded
|
|
||||||
-- List them here for Mikk's FindGlobals script
|
|
||||||
-- GLOBALS: LibStub
|
|
||||||
|
|
||||||
AceDB.db_registry = AceDB.db_registry or {}
|
AceDB.db_registry = AceDB.db_registry or {}
|
||||||
AceDB.frame = AceDB.frame or CreateFrame("Frame")
|
AceDB.frame = AceDB.frame or CreateFrame("Frame")
|
||||||
|
|
||||||
@ -98,11 +94,11 @@ local function copyDefaults(dest, src)
|
|||||||
-- This is a metatable used for table defaults
|
-- This is a metatable used for table defaults
|
||||||
local mt = {
|
local mt = {
|
||||||
-- This handles the lookup and creation of new subtables
|
-- This handles the lookup and creation of new subtables
|
||||||
__index = function(t,k)
|
__index = function(t,k2)
|
||||||
if k == nil then return nil end
|
if k2 == nil then return nil end
|
||||||
local tbl = {}
|
local tbl = {}
|
||||||
copyDefaults(tbl, v)
|
copyDefaults(tbl, v)
|
||||||
rawset(t, k, tbl)
|
rawset(t, k2, tbl)
|
||||||
return tbl
|
return tbl
|
||||||
end,
|
end,
|
||||||
}
|
}
|
||||||
@ -115,7 +111,7 @@ local function copyDefaults(dest, src)
|
|||||||
end
|
end
|
||||||
else
|
else
|
||||||
-- Values are not tables, so this is just a simple return
|
-- Values are not tables, so this is just a simple return
|
||||||
local mt = {__index = function(t,k) return k~=nil and v or nil end}
|
local mt = {__index = function(t,k2) return k2~=nil and v or nil end}
|
||||||
setmetatable(dest, mt)
|
setmetatable(dest, mt)
|
||||||
end
|
end
|
||||||
elseif type(v) == "table" then
|
elseif type(v) == "table" then
|
||||||
@ -264,7 +260,7 @@ local factionrealmKey = factionKey .. " - " .. realmKey
|
|||||||
local localeKey = GetLocale():lower()
|
local localeKey = GetLocale():lower()
|
||||||
|
|
||||||
local regionTable = { "US", "KR", "EU", "TW", "CN" }
|
local regionTable = { "US", "KR", "EU", "TW", "CN" }
|
||||||
local regionKey = regionTable[GetCurrentRegion()]
|
local regionKey = regionTable[GetCurrentRegion()] or GetCurrentRegionName() or "TR"
|
||||||
local factionrealmregionKey = factionrealmKey .. " - " .. regionKey
|
local factionrealmregionKey = factionrealmKey .. " - " .. regionKey
|
||||||
|
|
||||||
-- Actual database initialization function
|
-- Actual database initialization function
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
--- AceDBOptions-3.0 provides a universal AceConfig options screen for managing AceDB-3.0 profiles.
|
--- AceDBOptions-3.0 provides a universal AceConfig options screen for managing AceDB-3.0 profiles.
|
||||||
-- @class file
|
-- @class file
|
||||||
-- @name AceDBOptions-3.0
|
-- @name AceDBOptions-3.0
|
||||||
-- @release $Id: AceDBOptions-3.0.lua 1202 2019-05-15 23:11:22Z nevcairiel $
|
-- @release $Id: AceDBOptions-3.0.lua 1304 2023-05-19 19:50:10Z nevcairiel $
|
||||||
local ACEDBO_MAJOR, ACEDBO_MINOR = "AceDBOptions-3.0", 15
|
local ACEDBO_MAJOR, ACEDBO_MINOR = "AceDBOptions-3.0", 15
|
||||||
local AceDBOptions = LibStub:NewLibrary(ACEDBO_MAJOR, ACEDBO_MINOR)
|
local AceDBOptions = LibStub:NewLibrary(ACEDBO_MAJOR, ACEDBO_MINOR)
|
||||||
|
|
||||||
@ -13,10 +13,6 @@ local pairs, next = pairs, next
|
|||||||
-- WoW APIs
|
-- WoW APIs
|
||||||
local UnitClass = UnitClass
|
local UnitClass = UnitClass
|
||||||
|
|
||||||
-- Global vars/functions that we don't upvalue since they might get hooked, or upgraded
|
|
||||||
-- List them here for Mikk's FindGlobals script
|
|
||||||
-- GLOBALS: NORMAL_FONT_COLOR_CODE, FONT_COLOR_CODE_CLOSE
|
|
||||||
|
|
||||||
AceDBOptions.optionTables = AceDBOptions.optionTables or {}
|
AceDBOptions.optionTables = AceDBOptions.optionTables or {}
|
||||||
AceDBOptions.handlers = AceDBOptions.handlers or {}
|
AceDBOptions.handlers = AceDBOptions.handlers or {}
|
||||||
|
|
||||||
@ -88,25 +84,25 @@ elseif LOCALE == "frFR" then
|
|||||||
L["reset_desc"] = "Réinitialise le profil actuel au cas où votre configuration est corrompue ou si vous voulez tout simplement faire table rase."
|
L["reset_desc"] = "Réinitialise le profil actuel au cas où votre configuration est corrompue ou si vous voulez tout simplement faire table rase."
|
||||||
L["reset_sub"] = "Réinitialise le profil actuel avec les paramètres par défaut."
|
L["reset_sub"] = "Réinitialise le profil actuel avec les paramètres par défaut."
|
||||||
elseif LOCALE == "koKR" then
|
elseif LOCALE == "koKR" then
|
||||||
L["choose"] = "저장 중인 프로필"
|
L["choose"] = "기존 프로필"
|
||||||
L["choose_desc"] = "입력창에 새로운 이름을 입력하거나 저장 중인 프로필 중 하나를 선택하여 새로운 프로필을 만들 수 있습니다."
|
L["choose_desc"] = "편집 상자에 이름을 입력하여 새로운 프로필을 만들거나 이미 존재하는 프로필 중 하나를 선택할 수 있습니다."
|
||||||
L["choose_sub"] = "현재 이용할 수 있는 프로필 중 하나를 선택합니다."
|
L["choose_sub"] = "현재 이용할 수 있는 프로필 중 하나를 선택합니다."
|
||||||
L["copy"] = "복사해오기"
|
L["copy"] = "복사해 올 프로필"
|
||||||
L["copy_desc"] = "현재 사용 중인 프로필에 선택한 프로필의 설정을 복사합니다."
|
L["copy_desc"] = "기존 프로필의 설정을 현재 활성화된 프로필로 복사합니다."
|
||||||
L["current"] = "현재 프로필:"
|
L["current"] = "현재 프로필:"
|
||||||
L["default"] = "기본값"
|
L["default"] = "기본값"
|
||||||
L["delete"] = "프로필 삭제"
|
L["delete"] = "프로필 삭제"
|
||||||
L["delete_confirm"] = "정말로 선택한 프로필을 삭제할까요?"
|
L["delete_confirm"] = "선택한 프로필을 삭제하시겠습니까?"
|
||||||
L["delete_desc"] = "저장 공간 절약과 SavedVariables 파일의 정리를 위해 데이터베이스에서 사용하지 않는 프로필을 삭제하세요."
|
L["delete_desc"] = "데이터베이스에서 기존 프로필과 사용하지 않는 프로필을 삭제하여 공간을 절약하고 SavedVariables 파일을 정리합니다."
|
||||||
L["delete_sub"] = "데이터베이스의 프로필을 삭제합니다."
|
L["delete_sub"] = "데이터베이스에서 프로필을 삭제합니다."
|
||||||
L["intro"] = "활성 데이터베이스 프로필을 변경할 수 있고, 각 캐릭터 별로 다른 설정을 할 수 있습니다."
|
L["intro"] = "활성 데이터베이스 프로필을 변경할 수 있으며, 모든 캐릭터마다 서로 다른 설정을 지정할 수 있습니다."
|
||||||
L["new"] = "새로운 프로필"
|
L["new"] = "새로운 프로필"
|
||||||
L["new_sub"] = "새로운 프로필을 만듭니다."
|
L["new_sub"] = "비어 있는 프로필을 새로 만듭니다."
|
||||||
L["profiles"] = "프로필"
|
L["profiles"] = "프로필"
|
||||||
L["profiles_sub"] = "프로필 관리"
|
L["profiles_sub"] = "프로필 관리"
|
||||||
L["reset"] = "프로필 초기화"
|
L["reset"] = "프로필 재설정"
|
||||||
L["reset_desc"] = "설정이 깨졌거나 처음부터 다시 설정을 원하는 경우, 현재 프로필을 기본값으로 초기화하세요."
|
L["reset_desc"] = "구성이 손상되었거나 처음부터 다시 시작하고 싶은 경우 현재 프로필을 기본값으로 재설정하세요."
|
||||||
L["reset_sub"] = "현재 프로필을 기본값으로 초기화합니다"
|
L["reset_sub"] = "현재 프로필을 기본값으로 재설정합니다"
|
||||||
elseif LOCALE == "esES" or LOCALE == "esMX" then
|
elseif LOCALE == "esES" or LOCALE == "esMX" then
|
||||||
L["choose"] = "Perfiles existentes"
|
L["choose"] = "Perfiles existentes"
|
||||||
L["choose_desc"] = "Puedes crear un nuevo perfil introduciendo un nombre en el recuadro o puedes seleccionar un perfil de los ya existentes."
|
L["choose_desc"] = "Puedes crear un nuevo perfil introduciendo un nombre en el recuadro o puedes seleccionar un perfil de los ya existentes."
|
||||||
@ -170,31 +166,31 @@ elseif LOCALE == "zhCN" then
|
|||||||
elseif LOCALE == "ruRU" then
|
elseif LOCALE == "ruRU" then
|
||||||
L["choose"] = "Существующие профили"
|
L["choose"] = "Существующие профили"
|
||||||
L["choose_desc"] = "Вы можете создать новый профиль, введя название в поле ввода, или выбрать один из уже существующих профилей."
|
L["choose_desc"] = "Вы можете создать новый профиль, введя название в поле ввода, или выбрать один из уже существующих профилей."
|
||||||
L["choose_sub"] = "Выбор одиного из уже доступных профилей"
|
L["choose_sub"] = "Выбор одного из уже доступных профилей."
|
||||||
L["copy"] = "Скопировать из"
|
L["copy"] = "Скопировать из"
|
||||||
L["copy_desc"] = "Скопировать настройки из выбранного профиля в активный."
|
L["copy_desc"] = "Копирование настроек из выбранного профиля в активный."
|
||||||
L["current"] = "Текущий профиль:"
|
L["current"] = "Текущий профиль:"
|
||||||
L["default"] = "По умолчанию"
|
L["default"] = "По умолчанию"
|
||||||
L["delete"] = "Удалить профиль"
|
L["delete"] = "Удалить профиль"
|
||||||
L["delete_confirm"] = "Вы уверены, что вы хотите удалить выбранный профиль?"
|
L["delete_confirm"] = "Вы уверены, что хотите удалить выбранный профиль?"
|
||||||
L["delete_desc"] = "Удалить существующий и неиспользуемый профиль из БД для сохранения места, и очистить SavedVariables файл."
|
L["delete_desc"] = "Удаление существующего и неиспользуемого профиля из базы данных для сохранения места, и очистка файла SavedVariables."
|
||||||
L["delete_sub"] = "Удаление профиля из БД"
|
L["delete_sub"] = "Удаление профиля из базы данных."
|
||||||
L["intro"] = "Изменяя активный профиль, вы можете задать различные настройки модификаций для каждого персонажа."
|
L["intro"] = "Изменяя активный профиль, Вы можете задать разные настройки для каждого персонажа."
|
||||||
L["new"] = "Новый"
|
L["new"] = "Новый"
|
||||||
L["new_sub"] = "Создать новый чистый профиль"
|
L["new_sub"] = "Создание нового чистого профиля."
|
||||||
L["profiles"] = "Профили"
|
L["profiles"] = "Профили"
|
||||||
L["profiles_sub"] = "Управление профилями"
|
L["profiles_sub"] = "Управление профилями"
|
||||||
L["reset"] = "Сброс профиля"
|
L["reset"] = "Сбросить профиль"
|
||||||
L["reset_desc"] = "Сбросить текущий профиль к стандартным настройкам, если ваша конфигурация испорчена или вы хотите настроить всё заново."
|
L["reset_desc"] = "Сброс текущего профиля к стандартным настройкам, если Ваша конфигурация испорчена или Вы хотите настроить все заново."
|
||||||
L["reset_sub"] = "Сброс текущего профиля на стандартный"
|
L["reset_sub"] = "Сброс текущего профиля на стандартный"
|
||||||
elseif LOCALE == "itIT" then
|
elseif LOCALE == "itIT" then
|
||||||
L["choose"] = "Profili Esistenti"
|
L["choose"] = "Profili Esistenti"
|
||||||
L["choose_desc"] = "Puoi creare un nuovo profilo digitando il nome della casella di testo, oppure scegliendone uno tra i profili già esistenti."
|
L["choose_desc"] = "Puoi creare un nuovo profilo digitando il nome della casella di testo, oppure scegliendone uno tra i profili già esistenti."
|
||||||
L["choose_sub"] = "Seleziona uno dei profili attualmente disponibili."
|
L["choose_sub"] = "Seleziona uno dei profili attualmente disponibili."
|
||||||
L["copy"] = "Copia Da"
|
L["copy"] = "Copia Da"
|
||||||
L["copy_desc"] = "Copia le impostazioni da un profilo esistente, nel profilo attivo in questo momento."
|
L["copy_desc"] = "Copia le impostazioni da un profilo esistente nel profilo attivo in questo momento."
|
||||||
L["current"] = "Profilo Attivo:"
|
L["current"] = "Profilo Attivo:"
|
||||||
L["default"] = "Standard"
|
L["default"] = "Predefinito"
|
||||||
L["delete"] = "Cancella un Profilo"
|
L["delete"] = "Cancella un Profilo"
|
||||||
L["delete_confirm"] = "Sei sicuro di voler cancellare il profilo selezionato?"
|
L["delete_confirm"] = "Sei sicuro di voler cancellare il profilo selezionato?"
|
||||||
L["delete_desc"] = "Cancella i profili non utilizzati dal database per risparmiare spazio e mantenere puliti i file di configurazione SavedVariables."
|
L["delete_desc"] = "Cancella i profili non utilizzati dal database per risparmiare spazio e mantenere puliti i file di configurazione SavedVariables."
|
||||||
|
@ -24,28 +24,22 @@
|
|||||||
-- f:AddChild(btn)
|
-- f:AddChild(btn)
|
||||||
-- @class file
|
-- @class file
|
||||||
-- @name AceGUI-3.0
|
-- @name AceGUI-3.0
|
||||||
-- @release $Id: AceGUI-3.0.lua 1231 2020-04-14 22:20:36Z nevcairiel $
|
-- @release $Id: AceGUI-3.0.lua 1288 2022-09-25 14:19:00Z funkehdude $
|
||||||
local ACEGUI_MAJOR, ACEGUI_MINOR = "AceGUI-3.0", 41
|
local ACEGUI_MAJOR, ACEGUI_MINOR = "AceGUI-3.0", 41
|
||||||
local AceGUI, oldminor = LibStub:NewLibrary(ACEGUI_MAJOR, ACEGUI_MINOR)
|
local AceGUI, oldminor = LibStub:NewLibrary(ACEGUI_MAJOR, ACEGUI_MINOR)
|
||||||
|
|
||||||
if not AceGUI then return end -- No upgrade needed
|
if not AceGUI then return end -- No upgrade needed
|
||||||
|
|
||||||
-- Lua APIs
|
-- Lua APIs
|
||||||
local tinsert = table.insert
|
local tinsert, wipe = table.insert, table.wipe
|
||||||
local select, pairs, next, type = select, pairs, next, type
|
local select, pairs, next, type = select, pairs, next, type
|
||||||
local error, assert = error, assert
|
local error, assert = error, assert
|
||||||
local setmetatable, rawget = setmetatable, rawget
|
local setmetatable, rawget = setmetatable, rawget
|
||||||
local math_max = math.max
|
local math_max, math_min, math_ceil = math.max, math.min, math.ceil
|
||||||
|
|
||||||
-- WoW APIs
|
-- WoW APIs
|
||||||
local UIParent = UIParent
|
local UIParent = UIParent
|
||||||
|
|
||||||
-- Global vars/functions that we don't upvalue since they might get hooked, or upgraded
|
|
||||||
-- List them here for Mikk's FindGlobals script
|
|
||||||
-- GLOBALS: geterrorhandler, LibStub
|
|
||||||
|
|
||||||
--local con = LibStub("AceConsole-3.0",true)
|
|
||||||
|
|
||||||
AceGUI.WidgetRegistry = AceGUI.WidgetRegistry or {}
|
AceGUI.WidgetRegistry = AceGUI.WidgetRegistry or {}
|
||||||
AceGUI.LayoutRegistry = AceGUI.LayoutRegistry or {}
|
AceGUI.LayoutRegistry = AceGUI.LayoutRegistry or {}
|
||||||
AceGUI.WidgetBase = AceGUI.WidgetBase or {}
|
AceGUI.WidgetBase = AceGUI.WidgetBase or {}
|
||||||
@ -94,38 +88,38 @@ do
|
|||||||
AceGUI.objPools = AceGUI.objPools or {}
|
AceGUI.objPools = AceGUI.objPools or {}
|
||||||
local objPools = AceGUI.objPools
|
local objPools = AceGUI.objPools
|
||||||
--Returns a new instance, if none are available either returns a new table or calls the given contructor
|
--Returns a new instance, if none are available either returns a new table or calls the given contructor
|
||||||
function newWidget(type)
|
function newWidget(widgetType)
|
||||||
if not WidgetRegistry[type] then
|
if not WidgetRegistry[widgetType] then
|
||||||
error("Attempt to instantiate unknown widget type", 2)
|
error("Attempt to instantiate unknown widget type", 2)
|
||||||
end
|
end
|
||||||
|
|
||||||
if not objPools[type] then
|
if not objPools[widgetType] then
|
||||||
objPools[type] = {}
|
objPools[widgetType] = {}
|
||||||
end
|
end
|
||||||
|
|
||||||
local newObj = next(objPools[type])
|
local newObj = next(objPools[widgetType])
|
||||||
if not newObj then
|
if not newObj then
|
||||||
newObj = WidgetRegistry[type]()
|
newObj = WidgetRegistry[widgetType]()
|
||||||
newObj.AceGUIWidgetVersion = WidgetVersions[type]
|
newObj.AceGUIWidgetVersion = WidgetVersions[widgetType]
|
||||||
else
|
else
|
||||||
objPools[type][newObj] = nil
|
objPools[widgetType][newObj] = nil
|
||||||
-- if the widget is older then the latest, don't even try to reuse it
|
-- if the widget is older then the latest, don't even try to reuse it
|
||||||
-- just forget about it, and grab a new one.
|
-- just forget about it, and grab a new one.
|
||||||
if not newObj.AceGUIWidgetVersion or newObj.AceGUIWidgetVersion < WidgetVersions[type] then
|
if not newObj.AceGUIWidgetVersion or newObj.AceGUIWidgetVersion < WidgetVersions[widgetType] then
|
||||||
return newWidget(type)
|
return newWidget(widgetType)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
return newObj
|
return newObj
|
||||||
end
|
end
|
||||||
-- Releases an instance to the Pool
|
-- Releases an instance to the Pool
|
||||||
function delWidget(obj,type)
|
function delWidget(obj,widgetType)
|
||||||
if not objPools[type] then
|
if not objPools[widgetType] then
|
||||||
objPools[type] = {}
|
objPools[widgetType] = {}
|
||||||
end
|
end
|
||||||
if objPools[type][obj] then
|
if objPools[widgetType][obj] then
|
||||||
error("Attempt to Release Widget that is already released", 2)
|
error("Attempt to Release Widget that is already released", 2)
|
||||||
end
|
end
|
||||||
objPools[type][obj] = true
|
objPools[widgetType][obj] = true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -141,9 +135,9 @@ end
|
|||||||
-- OnAcquire function on it, before returning.
|
-- OnAcquire function on it, before returning.
|
||||||
-- @param type The type of the widget.
|
-- @param type The type of the widget.
|
||||||
-- @return The newly created widget.
|
-- @return The newly created widget.
|
||||||
function AceGUI:Create(type)
|
function AceGUI:Create(widgetType)
|
||||||
if WidgetRegistry[type] then
|
if WidgetRegistry[widgetType] then
|
||||||
local widget = newWidget(type)
|
local widget = newWidget(widgetType)
|
||||||
|
|
||||||
if rawget(widget, "Acquire") then
|
if rawget(widget, "Acquire") then
|
||||||
widget.OnAcquire = widget.Acquire
|
widget.OnAcquire = widget.Acquire
|
||||||
@ -161,7 +155,7 @@ function AceGUI:Create(type)
|
|||||||
if widget.OnAcquire then
|
if widget.OnAcquire then
|
||||||
widget:OnAcquire()
|
widget:OnAcquire()
|
||||||
else
|
else
|
||||||
error(("Widget type %s doesn't supply an OnAcquire Function"):format(type))
|
error(("Widget type %s doesn't supply an OnAcquire Function"):format(widgetType))
|
||||||
end
|
end
|
||||||
-- Set the default Layout ("List")
|
-- Set the default Layout ("List")
|
||||||
safecall(widget.SetLayout, widget, "List")
|
safecall(widget.SetLayout, widget, "List")
|
||||||
@ -589,25 +583,25 @@ AceGUI.counts = AceGUI.counts or {}
|
|||||||
-- This is used by widgets that require a named frame, e.g. when a Blizzard
|
-- This is used by widgets that require a named frame, e.g. when a Blizzard
|
||||||
-- Template requires it.
|
-- Template requires it.
|
||||||
-- @param type The widget type
|
-- @param type The widget type
|
||||||
function AceGUI:GetNextWidgetNum(type)
|
function AceGUI:GetNextWidgetNum(widgetType)
|
||||||
if not self.counts[type] then
|
if not self.counts[widgetType] then
|
||||||
self.counts[type] = 0
|
self.counts[widgetType] = 0
|
||||||
end
|
end
|
||||||
self.counts[type] = self.counts[type] + 1
|
self.counts[widgetType] = self.counts[widgetType] + 1
|
||||||
return self.counts[type]
|
return self.counts[widgetType]
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Return the number of created widgets for this type.
|
--- Return the number of created widgets for this type.
|
||||||
-- In contrast to GetNextWidgetNum, the number is not incremented.
|
-- In contrast to GetNextWidgetNum, the number is not incremented.
|
||||||
-- @param type The widget type
|
-- @param widgetType The widget type
|
||||||
function AceGUI:GetWidgetCount(type)
|
function AceGUI:GetWidgetCount(widgetType)
|
||||||
return self.counts[type] or 0
|
return self.counts[widgetType] or 0
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Return the version of the currently registered widget type.
|
--- Return the version of the currently registered widget type.
|
||||||
-- @param type The widget type
|
-- @param widgetType The widget type
|
||||||
function AceGUI:GetWidgetVersion(type)
|
function AceGUI:GetWidgetVersion(widgetType)
|
||||||
return WidgetVersions[type]
|
return WidgetVersions[widgetType]
|
||||||
end
|
end
|
||||||
|
|
||||||
-------------
|
-------------
|
||||||
@ -770,7 +764,6 @@ AceGUI:RegisterLayout("Flow",
|
|||||||
|
|
||||||
usedwidth = 0
|
usedwidth = 0
|
||||||
rowstart = frame
|
rowstart = frame
|
||||||
rowstartoffset = frameoffset
|
|
||||||
|
|
||||||
if child.DoLayout then
|
if child.DoLayout then
|
||||||
child:DoLayout()
|
child:DoLayout()
|
||||||
@ -813,7 +806,8 @@ local GetCellAlign = function (dir, tableObj, colObj, cellObj, cell, child)
|
|||||||
or colObj and (colObj["align" .. dir] or colObj.align)
|
or colObj and (colObj["align" .. dir] or colObj.align)
|
||||||
or tableObj["align" .. dir] or tableObj.align
|
or tableObj["align" .. dir] or tableObj.align
|
||||||
or "CENTERLEFT"
|
or "CENTERLEFT"
|
||||||
local child, cell, val = child or 0, cell or 0, nil
|
local val
|
||||||
|
child, cell = child or 0, cell or 0
|
||||||
|
|
||||||
if type(fn) == "string" then
|
if type(fn) == "string" then
|
||||||
fn = fn:lower()
|
fn = fn:lower()
|
||||||
@ -827,7 +821,7 @@ local GetCellAlign = function (dir, tableObj, colObj, cellObj, cell, child)
|
|||||||
val = fn
|
val = fn
|
||||||
end
|
end
|
||||||
|
|
||||||
return fn, max(0, min(val, cell))
|
return fn, math_max(0, math_min(val, cell))
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Get width or height for multiple cells combined
|
-- Get width or height for multiple cells combined
|
||||||
@ -836,7 +830,7 @@ local GetCellDimension = function (dir, laneDim, from, to, space)
|
|||||||
for cell=from,to do
|
for cell=from,to do
|
||||||
dim = dim + (laneDim[cell] or 0)
|
dim = dim + (laneDim[cell] or 0)
|
||||||
end
|
end
|
||||||
return dim + max(0, to - from) * (space or 0)
|
return dim + math_max(0, to - from) * (space or 0)
|
||||||
end
|
end
|
||||||
|
|
||||||
--[[ Options
|
--[[ Options
|
||||||
@ -882,7 +876,7 @@ AceGUI:RegisterLayout("Table",
|
|||||||
repeat
|
repeat
|
||||||
n = n + 1
|
n = n + 1
|
||||||
local col = (n - 1) % #cols + 1
|
local col = (n - 1) % #cols + 1
|
||||||
local row = ceil(n / #cols)
|
local row = math_ceil(n / #cols)
|
||||||
local rowspan = rowspans[col]
|
local rowspan = rowspans[col]
|
||||||
local cell = rowspan and rowspan.child or child
|
local cell = rowspan and rowspan.child or child
|
||||||
local cellObj = cell:GetUserData("cell")
|
local cellObj = cell:GetUserData("cell")
|
||||||
@ -898,7 +892,7 @@ AceGUI:RegisterLayout("Table",
|
|||||||
end
|
end
|
||||||
|
|
||||||
-- Colspan
|
-- Colspan
|
||||||
local colspan = max(0, min((cellObj and cellObj.colspan or 1) - 1, #cols - col))
|
local colspan = math_max(0, math_min((cellObj and cellObj.colspan or 1) - 1, #cols - col))
|
||||||
n = n + colspan
|
n = n + colspan
|
||||||
|
|
||||||
-- Place the cell
|
-- Place the cell
|
||||||
@ -915,7 +909,7 @@ AceGUI:RegisterLayout("Table",
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local rows = ceil(n / #cols)
|
local rows = math_ceil(n / #cols)
|
||||||
|
|
||||||
-- Determine fixed size cols and collect weights
|
-- Determine fixed size cols and collect weights
|
||||||
local extantH, totalWeight = totalH, 0
|
local extantH, totalWeight = totalH, 0
|
||||||
@ -940,16 +934,16 @@ AceGUI:RegisterLayout("Table",
|
|||||||
f:ClearAllPoints()
|
f:ClearAllPoints()
|
||||||
local childH = f:GetWidth() or 0
|
local childH = f:GetWidth() or 0
|
||||||
|
|
||||||
laneH[col] = max(laneH[col], childH - GetCellDimension("H", laneH, colStart[child], col - 1, spaceH))
|
laneH[col] = math_max(laneH[col], childH - GetCellDimension("H", laneH, colStart[child], col - 1, spaceH))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
laneH[col] = max(colObj.min or colObj[1] or 0, min(laneH[col], colObj.max or colObj[2] or laneH[col]))
|
laneH[col] = math_max(colObj.min or colObj[1] or 0, math_min(laneH[col], colObj.max or colObj[2] or laneH[col]))
|
||||||
else
|
else
|
||||||
-- Rel./Abs. width
|
-- Rel./Abs. width
|
||||||
laneH[col] = colObj.width < 1 and colObj.width * totalH or colObj.width
|
laneH[col] = colObj.width < 1 and colObj.width * totalH or colObj.width
|
||||||
end
|
end
|
||||||
extantH = max(0, extantH - laneH[col])
|
extantH = math_max(0, extantH - laneH[col])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -988,7 +982,7 @@ AceGUI:RegisterLayout("Table",
|
|||||||
child:DoLayout()
|
child:DoLayout()
|
||||||
end
|
end
|
||||||
|
|
||||||
rowV = max(rowV, (f:GetHeight() or 0) - GetCellDimension("V", laneV, rowStart[child], row - 1, spaceV))
|
rowV = math_max(rowV, (f:GetHeight() or 0) - GetCellDimension("V", laneV, rowStart[child], row - 1, spaceV))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
BlizOptionsGroup Container
|
BlizOptionsGroup Container
|
||||||
Simple container widget for the integration of AceGUI into the Blizzard Interface Options
|
Simple container widget for the integration of AceGUI into the Blizzard Interface Options
|
||||||
-------------------------------------------------------------------------------]]
|
-------------------------------------------------------------------------------]]
|
||||||
local Type, Version = "BlizOptionsGroup", 21
|
local Type, Version = "BlizOptionsGroup", 26
|
||||||
local AceGUI = LibStub and LibStub("AceGUI-3.0", true)
|
local AceGUI = LibStub and LibStub("AceGUI-3.0", true)
|
||||||
if not AceGUI or (AceGUI:GetWidgetVersion(Type) or 0) >= Version then return end
|
if not AceGUI or (AceGUI:GetWidgetVersion(Type) or 0) >= Version then return end
|
||||||
|
|
||||||
@ -99,7 +99,7 @@ local methods = {
|
|||||||
Constructor
|
Constructor
|
||||||
-------------------------------------------------------------------------------]]
|
-------------------------------------------------------------------------------]]
|
||||||
local function Constructor()
|
local function Constructor()
|
||||||
local frame = CreateFrame("Frame")
|
local frame = CreateFrame("Frame", nil, InterfaceOptionsFramePanelContainer)
|
||||||
frame:Hide()
|
frame:Hide()
|
||||||
|
|
||||||
-- support functions for the Blizzard Interface Options
|
-- support functions for the Blizzard Interface Options
|
||||||
@ -108,6 +108,11 @@ local function Constructor()
|
|||||||
frame.default = default
|
frame.default = default
|
||||||
frame.refresh = refresh
|
frame.refresh = refresh
|
||||||
|
|
||||||
|
-- 10.0 support function aliases (cancel has been removed)
|
||||||
|
frame.OnCommit = okay
|
||||||
|
frame.OnDefault = default
|
||||||
|
frame.OnRefresh = refresh
|
||||||
|
|
||||||
frame:SetScript("OnHide", OnHide)
|
frame:SetScript("OnHide", OnHide)
|
||||||
frame:SetScript("OnShow", OnShow)
|
frame:SetScript("OnShow", OnShow)
|
||||||
|
|
||||||
|
@ -125,7 +125,7 @@ local function Constructor()
|
|||||||
dropdown.frame:Show()
|
dropdown.frame:Show()
|
||||||
dropdown:SetLabel("")
|
dropdown:SetLabel("")
|
||||||
|
|
||||||
local border = CreateFrame("Frame", nil, frame, BackdropTemplateMixin and "BackdropTemplate" or nil)
|
local border = CreateFrame("Frame", nil, frame, "BackdropTemplate")
|
||||||
border:SetPoint("TOPLEFT", 0, -26)
|
border:SetPoint("TOPLEFT", 0, -26)
|
||||||
border:SetPoint("BOTTOMRIGHT", 0, 3)
|
border:SetPoint("BOTTOMRIGHT", 0, 3)
|
||||||
border:SetBackdrop(PaneBackdrop)
|
border:SetBackdrop(PaneBackdrop)
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
--[[-----------------------------------------------------------------------------
|
--[[-----------------------------------------------------------------------------
|
||||||
Frame Container
|
Frame Container
|
||||||
-------------------------------------------------------------------------------]]
|
-------------------------------------------------------------------------------]]
|
||||||
local Type, Version = "Frame", 27
|
local Type, Version = "Frame", 30
|
||||||
local AceGUI = LibStub and LibStub("AceGUI-3.0", true)
|
local AceGUI = LibStub and LibStub("AceGUI-3.0", true)
|
||||||
if not AceGUI or (AceGUI:GetWidgetVersion(Type) or 0) >= Version then return end
|
if not AceGUI or (AceGUI:GetWidgetVersion(Type) or 0) >= Version then return end
|
||||||
|
|
||||||
@ -13,10 +13,6 @@ local wipe = table.wipe
|
|||||||
local PlaySound = PlaySound
|
local PlaySound = PlaySound
|
||||||
local CreateFrame, UIParent = CreateFrame, UIParent
|
local CreateFrame, UIParent = CreateFrame, UIParent
|
||||||
|
|
||||||
-- Global vars/functions that we don't upvalue since they might get hooked, or upgraded
|
|
||||||
-- List them here for Mikk's FindGlobals script
|
|
||||||
-- GLOBALS: CLOSE
|
|
||||||
|
|
||||||
--[[-----------------------------------------------------------------------------
|
--[[-----------------------------------------------------------------------------
|
||||||
Scripts
|
Scripts
|
||||||
-------------------------------------------------------------------------------]]
|
-------------------------------------------------------------------------------]]
|
||||||
@ -83,6 +79,7 @@ local methods = {
|
|||||||
["OnAcquire"] = function(self)
|
["OnAcquire"] = function(self)
|
||||||
self.frame:SetParent(UIParent)
|
self.frame:SetParent(UIParent)
|
||||||
self.frame:SetFrameStrata("FULLSCREEN_DIALOG")
|
self.frame:SetFrameStrata("FULLSCREEN_DIALOG")
|
||||||
|
self.frame:SetFrameLevel(100) -- Lots of room to draw under it
|
||||||
self:SetTitle()
|
self:SetTitle()
|
||||||
self:SetStatusText()
|
self:SetStatusText()
|
||||||
self:ApplyStatus()
|
self:ApplyStatus()
|
||||||
@ -179,16 +176,21 @@ local PaneBackdrop = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
local function Constructor()
|
local function Constructor()
|
||||||
local frame = CreateFrame("Frame", nil, UIParent, BackdropTemplateMixin and "BackdropTemplate" or nil)
|
local frame = CreateFrame("Frame", nil, UIParent, "BackdropTemplate")
|
||||||
frame:Hide()
|
frame:Hide()
|
||||||
|
|
||||||
frame:EnableMouse(true)
|
frame:EnableMouse(true)
|
||||||
frame:SetMovable(true)
|
frame:SetMovable(true)
|
||||||
frame:SetResizable(true)
|
frame:SetResizable(true)
|
||||||
frame:SetFrameStrata("FULLSCREEN_DIALOG")
|
frame:SetFrameStrata("FULLSCREEN_DIALOG")
|
||||||
|
frame:SetFrameLevel(100) -- Lots of room to draw under it
|
||||||
frame:SetBackdrop(FrameBackdrop)
|
frame:SetBackdrop(FrameBackdrop)
|
||||||
frame:SetBackdropColor(0, 0, 0, 1)
|
frame:SetBackdropColor(0, 0, 0, 1)
|
||||||
frame:SetMinResize(400, 200)
|
if frame.SetResizeBounds then -- WoW 10.0
|
||||||
|
frame:SetResizeBounds(400, 200)
|
||||||
|
else
|
||||||
|
frame:SetMinResize(400, 200)
|
||||||
|
end
|
||||||
frame:SetToplevel(true)
|
frame:SetToplevel(true)
|
||||||
frame:SetScript("OnShow", Frame_OnShow)
|
frame:SetScript("OnShow", Frame_OnShow)
|
||||||
frame:SetScript("OnHide", Frame_OnClose)
|
frame:SetScript("OnHide", Frame_OnClose)
|
||||||
@ -201,7 +203,7 @@ local function Constructor()
|
|||||||
closebutton:SetWidth(100)
|
closebutton:SetWidth(100)
|
||||||
closebutton:SetText(CLOSE)
|
closebutton:SetText(CLOSE)
|
||||||
|
|
||||||
local statusbg = CreateFrame("Button", nil, frame, BackdropTemplateMixin and "BackdropTemplate" or nil)
|
local statusbg = CreateFrame("Button", nil, frame, "BackdropTemplate")
|
||||||
statusbg:SetPoint("BOTTOMLEFT", 15, 15)
|
statusbg:SetPoint("BOTTOMLEFT", 15, 15)
|
||||||
statusbg:SetPoint("BOTTOMRIGHT", -132, 15)
|
statusbg:SetPoint("BOTTOMRIGHT", -132, 15)
|
||||||
statusbg:SetHeight(24)
|
statusbg:SetHeight(24)
|
||||||
@ -269,7 +271,7 @@ local function Constructor()
|
|||||||
line2:SetHeight(8)
|
line2:SetHeight(8)
|
||||||
line2:SetPoint("BOTTOMRIGHT", -8, 8)
|
line2:SetPoint("BOTTOMRIGHT", -8, 8)
|
||||||
line2:SetTexture(137057) -- Interface\\Tooltips\\UI-Tooltip-Border
|
line2:SetTexture(137057) -- Interface\\Tooltips\\UI-Tooltip-Border
|
||||||
local x = 0.1 * 8/17
|
x = 0.1 * 8/17
|
||||||
line2:SetTexCoord(0.05 - x, 0.5, 0.05, 0.5 + x, 0.05, 0.5 - x, 0.5 + x, 0.5)
|
line2:SetTexCoord(0.05 - x, 0.5, 0.05, 0.5 + x, 0.05, 0.5 - x, 0.5 + x, 0.5)
|
||||||
|
|
||||||
local sizer_s = CreateFrame("Frame", nil, frame)
|
local sizer_s = CreateFrame("Frame", nil, frame)
|
||||||
|
@ -75,7 +75,7 @@ local function Constructor()
|
|||||||
titletext:SetJustifyH("LEFT")
|
titletext:SetJustifyH("LEFT")
|
||||||
titletext:SetHeight(18)
|
titletext:SetHeight(18)
|
||||||
|
|
||||||
local border = CreateFrame("Frame", nil, frame, BackdropTemplateMixin and "BackdropTemplate" or nil)
|
local border = CreateFrame("Frame", nil, frame, "BackdropTemplate")
|
||||||
border:SetPoint("TOPLEFT", 0, -17)
|
border:SetPoint("TOPLEFT", 0, -17)
|
||||||
border:SetPoint("BOTTOMRIGHT", -1, 3)
|
border:SetPoint("BOTTOMRIGHT", -1, 3)
|
||||||
border:SetBackdrop(PaneBackdrop)
|
border:SetBackdrop(PaneBackdrop)
|
||||||
|
@ -2,22 +2,18 @@
|
|||||||
TabGroup Container
|
TabGroup Container
|
||||||
Container that uses tabs on top to switch between groups.
|
Container that uses tabs on top to switch between groups.
|
||||||
-------------------------------------------------------------------------------]]
|
-------------------------------------------------------------------------------]]
|
||||||
local Type, Version = "TabGroup", 37
|
local Type, Version = "TabGroup", 38
|
||||||
local AceGUI = LibStub and LibStub("AceGUI-3.0", true)
|
local AceGUI = LibStub and LibStub("AceGUI-3.0", true)
|
||||||
if not AceGUI or (AceGUI:GetWidgetVersion(Type) or 0) >= Version then return end
|
if not AceGUI or (AceGUI:GetWidgetVersion(Type) or 0) >= Version then return end
|
||||||
|
|
||||||
-- Lua APIs
|
-- Lua APIs
|
||||||
local pairs, ipairs, assert, type, wipe = pairs, ipairs, assert, type, wipe
|
local pairs, ipairs, assert, type, wipe = pairs, ipairs, assert, type, table.wipe
|
||||||
|
|
||||||
-- WoW APIs
|
-- WoW APIs
|
||||||
local PlaySound = PlaySound
|
local PlaySound = PlaySound
|
||||||
local CreateFrame, UIParent = CreateFrame, UIParent
|
local CreateFrame, UIParent = CreateFrame, UIParent
|
||||||
local _G = _G
|
local _G = _G
|
||||||
|
|
||||||
-- Global vars/functions that we don't upvalue since they might get hooked, or upgraded
|
|
||||||
-- List them here for Mikk's FindGlobals script
|
|
||||||
-- GLOBALS: PanelTemplates_TabResize, PanelTemplates_SetDisabledTabState, PanelTemplates_SelectTab, PanelTemplates_DeselectTab
|
|
||||||
|
|
||||||
-- local upvalue storage used by BuildTabs
|
-- local upvalue storage used by BuildTabs
|
||||||
local widths = {}
|
local widths = {}
|
||||||
local rowwidths = {}
|
local rowwidths = {}
|
||||||
@ -26,6 +22,143 @@ local rowends = {}
|
|||||||
--[[-----------------------------------------------------------------------------
|
--[[-----------------------------------------------------------------------------
|
||||||
Support functions
|
Support functions
|
||||||
-------------------------------------------------------------------------------]]
|
-------------------------------------------------------------------------------]]
|
||||||
|
|
||||||
|
local function PanelTemplates_TabResize(tab, padding, absoluteSize, minWidth, maxWidth, absoluteTextSize)
|
||||||
|
local tabName = tab:GetName();
|
||||||
|
|
||||||
|
local buttonMiddle = tab.Middle or tab.middleTexture or _G[tabName.."Middle"];
|
||||||
|
local buttonMiddleDisabled = tab.MiddleDisabled or (tabName and _G[tabName.."MiddleDisabled"]);
|
||||||
|
local left = tab.Left or tab.leftTexture or _G[tabName.."Left"];
|
||||||
|
local sideWidths = 2 * left:GetWidth();
|
||||||
|
local tabText = tab.Text or _G[tab:GetName().."Text"];
|
||||||
|
local highlightTexture = tab.HighlightTexture or (tabName and _G[tabName.."HighlightTexture"]);
|
||||||
|
|
||||||
|
local width, tabWidth;
|
||||||
|
local textWidth;
|
||||||
|
if ( absoluteTextSize ) then
|
||||||
|
textWidth = absoluteTextSize;
|
||||||
|
else
|
||||||
|
tabText:SetWidth(0);
|
||||||
|
textWidth = tabText:GetWidth();
|
||||||
|
end
|
||||||
|
-- If there's an absolute size specified then use it
|
||||||
|
if ( absoluteSize ) then
|
||||||
|
if ( absoluteSize < sideWidths) then
|
||||||
|
width = 1;
|
||||||
|
tabWidth = sideWidths
|
||||||
|
else
|
||||||
|
width = absoluteSize - sideWidths;
|
||||||
|
tabWidth = absoluteSize
|
||||||
|
end
|
||||||
|
tabText:SetWidth(width);
|
||||||
|
else
|
||||||
|
-- Otherwise try to use padding
|
||||||
|
if ( padding ) then
|
||||||
|
width = textWidth + padding;
|
||||||
|
else
|
||||||
|
width = textWidth + 24;
|
||||||
|
end
|
||||||
|
-- If greater than the maxWidth then cap it
|
||||||
|
if ( maxWidth and width > maxWidth ) then
|
||||||
|
if ( padding ) then
|
||||||
|
width = maxWidth + padding;
|
||||||
|
else
|
||||||
|
width = maxWidth + 24;
|
||||||
|
end
|
||||||
|
tabText:SetWidth(width);
|
||||||
|
else
|
||||||
|
tabText:SetWidth(0);
|
||||||
|
end
|
||||||
|
if (minWidth and width < minWidth) then
|
||||||
|
width = minWidth;
|
||||||
|
end
|
||||||
|
tabWidth = width + sideWidths;
|
||||||
|
end
|
||||||
|
|
||||||
|
if ( buttonMiddle ) then
|
||||||
|
buttonMiddle:SetWidth(width);
|
||||||
|
end
|
||||||
|
if ( buttonMiddleDisabled ) then
|
||||||
|
buttonMiddleDisabled:SetWidth(width);
|
||||||
|
end
|
||||||
|
|
||||||
|
tab:SetWidth(tabWidth);
|
||||||
|
|
||||||
|
if ( highlightTexture ) then
|
||||||
|
highlightTexture:SetWidth(tabWidth);
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local function PanelTemplates_DeselectTab(tab)
|
||||||
|
local name = tab:GetName();
|
||||||
|
|
||||||
|
local left = tab.Left or _G[name.."Left"];
|
||||||
|
local middle = tab.Middle or _G[name.."Middle"];
|
||||||
|
local right = tab.Right or _G[name.."Right"];
|
||||||
|
left:Show();
|
||||||
|
middle:Show();
|
||||||
|
right:Show();
|
||||||
|
--tab:UnlockHighlight();
|
||||||
|
tab:Enable();
|
||||||
|
local text = tab.Text or _G[name.."Text"];
|
||||||
|
text:SetPoint("CENTER", tab, "CENTER", (tab.deselectedTextX or 0), (tab.deselectedTextY or 2));
|
||||||
|
|
||||||
|
local leftDisabled = tab.LeftDisabled or _G[name.."LeftDisabled"];
|
||||||
|
local middleDisabled = tab.MiddleDisabled or _G[name.."MiddleDisabled"];
|
||||||
|
local rightDisabled = tab.RightDisabled or _G[name.."RightDisabled"];
|
||||||
|
leftDisabled:Hide();
|
||||||
|
middleDisabled:Hide();
|
||||||
|
rightDisabled:Hide();
|
||||||
|
end
|
||||||
|
|
||||||
|
local function PanelTemplates_SelectTab(tab)
|
||||||
|
local name = tab:GetName();
|
||||||
|
|
||||||
|
local left = tab.Left or _G[name.."Left"];
|
||||||
|
local middle = tab.Middle or _G[name.."Middle"];
|
||||||
|
local right = tab.Right or _G[name.."Right"];
|
||||||
|
left:Hide();
|
||||||
|
middle:Hide();
|
||||||
|
right:Hide();
|
||||||
|
--tab:LockHighlight();
|
||||||
|
tab:Disable();
|
||||||
|
tab:SetDisabledFontObject(GameFontHighlightSmall);
|
||||||
|
local text = tab.Text or _G[name.."Text"];
|
||||||
|
text:SetPoint("CENTER", tab, "CENTER", (tab.selectedTextX or 0), (tab.selectedTextY or -3));
|
||||||
|
|
||||||
|
local leftDisabled = tab.LeftDisabled or _G[name.."LeftDisabled"];
|
||||||
|
local middleDisabled = tab.MiddleDisabled or _G[name.."MiddleDisabled"];
|
||||||
|
local rightDisabled = tab.RightDisabled or _G[name.."RightDisabled"];
|
||||||
|
leftDisabled:Show();
|
||||||
|
middleDisabled:Show();
|
||||||
|
rightDisabled:Show();
|
||||||
|
|
||||||
|
if GameTooltip:IsOwned(tab) then
|
||||||
|
GameTooltip:Hide();
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local function PanelTemplates_SetDisabledTabState(tab)
|
||||||
|
local name = tab:GetName();
|
||||||
|
local left = tab.Left or _G[name.."Left"];
|
||||||
|
local middle = tab.Middle or _G[name.."Middle"];
|
||||||
|
local right = tab.Right or _G[name.."Right"];
|
||||||
|
left:Show();
|
||||||
|
middle:Show();
|
||||||
|
right:Show();
|
||||||
|
--tab:UnlockHighlight();
|
||||||
|
tab:Disable();
|
||||||
|
tab.text = tab:GetText();
|
||||||
|
-- Gray out text
|
||||||
|
tab:SetDisabledFontObject(GameFontDisableSmall);
|
||||||
|
local leftDisabled = tab.LeftDisabled or _G[name.."LeftDisabled"];
|
||||||
|
local middleDisabled = tab.MiddleDisabled or _G[name.."MiddleDisabled"];
|
||||||
|
local rightDisabled = tab.RightDisabled or _G[name.."RightDisabled"];
|
||||||
|
leftDisabled:Hide();
|
||||||
|
middleDisabled:Hide();
|
||||||
|
rightDisabled:Hide();
|
||||||
|
end
|
||||||
|
|
||||||
local function UpdateTabLook(frame)
|
local function UpdateTabLook(frame)
|
||||||
if frame.disabled then
|
if frame.disabled then
|
||||||
PanelTemplates_SetDisabledTabState(frame)
|
PanelTemplates_SetDisabledTabState(frame)
|
||||||
@ -103,11 +236,64 @@ local methods = {
|
|||||||
|
|
||||||
["CreateTab"] = function(self, id)
|
["CreateTab"] = function(self, id)
|
||||||
local tabname = ("AceGUITabGroup%dTab%d"):format(self.num, id)
|
local tabname = ("AceGUITabGroup%dTab%d"):format(self.num, id)
|
||||||
local tab = CreateFrame("Button", tabname, self.border, "OptionsFrameTabButtonTemplate")
|
local tab = CreateFrame("Button", tabname, self.border)
|
||||||
|
tab:SetSize(115, 24)
|
||||||
|
tab.deselectedTextY = -3
|
||||||
|
tab.selectedTextY = -2
|
||||||
|
|
||||||
|
tab.LeftDisabled = tab:CreateTexture(tabname .. "LeftDisabled", "BORDER")
|
||||||
|
tab.LeftDisabled:SetTexture("Interface\\OptionsFrame\\UI-OptionsFrame-ActiveTab")
|
||||||
|
tab.LeftDisabled:SetSize(20, 24)
|
||||||
|
tab.LeftDisabled:SetPoint("BOTTOMLEFT", 0, -3)
|
||||||
|
tab.LeftDisabled:SetTexCoord(0, 0.15625, 0, 1.0)
|
||||||
|
|
||||||
|
tab.MiddleDisabled = tab:CreateTexture(tabname .. "MiddleDisabled", "BORDER")
|
||||||
|
tab.MiddleDisabled:SetTexture("Interface\\OptionsFrame\\UI-OptionsFrame-ActiveTab")
|
||||||
|
tab.MiddleDisabled:SetSize(88, 24)
|
||||||
|
tab.MiddleDisabled:SetPoint("LEFT", tab.LeftDisabled, "RIGHT")
|
||||||
|
tab.MiddleDisabled:SetTexCoord(0.15625, 0.84375, 0, 1.0)
|
||||||
|
|
||||||
|
tab.RightDisabled = tab:CreateTexture(tabname .. "RightDisabled", "BORDER")
|
||||||
|
tab.RightDisabled:SetTexture("Interface\\OptionsFrame\\UI-OptionsFrame-ActiveTab")
|
||||||
|
tab.RightDisabled:SetSize(20, 24)
|
||||||
|
tab.RightDisabled:SetPoint("LEFT", tab.MiddleDisabled, "RIGHT")
|
||||||
|
tab.RightDisabled:SetTexCoord(0.84375, 1.0, 0, 1.0)
|
||||||
|
|
||||||
|
tab.Left = tab:CreateTexture(tabname .. "Left", "BORDER")
|
||||||
|
tab.Left:SetTexture("Interface\\OptionsFrame\\UI-OptionsFrame-InActiveTab")
|
||||||
|
tab.Left:SetSize(20, 24)
|
||||||
|
tab.Left:SetPoint("TOPLEFT")
|
||||||
|
tab.Left:SetTexCoord(0, 0.15625, 0, 1.0)
|
||||||
|
|
||||||
|
tab.Middle = tab:CreateTexture(tabname .. "Middle", "BORDER")
|
||||||
|
tab.Middle:SetTexture("Interface\\OptionsFrame\\UI-OptionsFrame-InActiveTab")
|
||||||
|
tab.Middle:SetSize(88, 24)
|
||||||
|
tab.Middle:SetPoint("LEFT", tab.Left, "RIGHT")
|
||||||
|
tab.Middle:SetTexCoord(0.15625, 0.84375, 0, 1.0)
|
||||||
|
|
||||||
|
tab.Right = tab:CreateTexture(tabname .. "Right", "BORDER")
|
||||||
|
tab.Right:SetTexture("Interface\\OptionsFrame\\UI-OptionsFrame-InActiveTab")
|
||||||
|
tab.Right:SetSize(20, 24)
|
||||||
|
tab.Right:SetPoint("LEFT", tab.Middle, "RIGHT")
|
||||||
|
tab.Right:SetTexCoord(0.84375, 1.0, 0, 1.0)
|
||||||
|
|
||||||
|
tab.Text = tab:CreateFontString(tabname .. "Text")
|
||||||
|
tab:SetFontString(tab.Text)
|
||||||
|
|
||||||
|
tab:SetNormalFontObject(GameFontNormalSmall)
|
||||||
|
tab:SetHighlightFontObject(GameFontHighlightSmall)
|
||||||
|
tab:SetDisabledFontObject(GameFontHighlightSmall)
|
||||||
|
tab:SetHighlightTexture("Interface\\PaperDollInfoFrame\\UI-Character-Tab-Highlight", "ADD")
|
||||||
|
tab.HighlightTexture = tab:GetHighlightTexture()
|
||||||
|
tab.HighlightTexture:ClearAllPoints()
|
||||||
|
tab.HighlightTexture:SetPoint("LEFT", tab, "LEFT", 10, -4)
|
||||||
|
tab.HighlightTexture:SetPoint("RIGHT", tab, "RIGHT", -10, -4)
|
||||||
|
_G[tabname .. "HighlightTexture"] = tab.HighlightTexture
|
||||||
|
|
||||||
tab.obj = self
|
tab.obj = self
|
||||||
tab.id = id
|
tab.id = id
|
||||||
|
|
||||||
tab.text = _G[tabname .. "Text"]
|
tab.text = tab.Text -- compat
|
||||||
tab.text:ClearAllPoints()
|
tab.text:ClearAllPoints()
|
||||||
tab.text:SetPoint("LEFT", 14, -3)
|
tab.text:SetPoint("LEFT", 14, -3)
|
||||||
tab.text:SetPoint("RIGHT", -12, -3)
|
tab.text:SetPoint("RIGHT", -12, -3)
|
||||||
@ -316,7 +502,7 @@ local function Constructor()
|
|||||||
titletext:SetHeight(18)
|
titletext:SetHeight(18)
|
||||||
titletext:SetText("")
|
titletext:SetText("")
|
||||||
|
|
||||||
local border = CreateFrame("Frame", nil, frame, BackdropTemplateMixin and "BackdropTemplate" or nil)
|
local border = CreateFrame("Frame", nil, frame, "BackdropTemplate")
|
||||||
border:SetPoint("TOPLEFT", 1, -27)
|
border:SetPoint("TOPLEFT", 1, -27)
|
||||||
border:SetPoint("BOTTOMRIGHT", -1, 3)
|
border:SetPoint("BOTTOMRIGHT", -1, 3)
|
||||||
border:SetBackdrop(PaneBackdrop)
|
border:SetBackdrop(PaneBackdrop)
|
||||||
|
@ -2,22 +2,18 @@
|
|||||||
TreeGroup Container
|
TreeGroup Container
|
||||||
Container that uses a tree control to switch between groups.
|
Container that uses a tree control to switch between groups.
|
||||||
-------------------------------------------------------------------------------]]
|
-------------------------------------------------------------------------------]]
|
||||||
local Type, Version = "TreeGroup", 45
|
local Type, Version = "TreeGroup", 47
|
||||||
local AceGUI = LibStub and LibStub("AceGUI-3.0", true)
|
local AceGUI = LibStub and LibStub("AceGUI-3.0", true)
|
||||||
if not AceGUI or (AceGUI:GetWidgetVersion(Type) or 0) >= Version then return end
|
if not AceGUI or (AceGUI:GetWidgetVersion(Type) or 0) >= Version then return end
|
||||||
|
|
||||||
-- Lua APIs
|
-- Lua APIs
|
||||||
local next, pairs, ipairs, assert, type = next, pairs, ipairs, assert, type
|
local next, pairs, ipairs, assert, type = next, pairs, ipairs, assert, type
|
||||||
local math_min, math_max, floor = math.min, math.max, floor
|
local math_min, math_max, floor = math.min, math.max, math.floor
|
||||||
local select, tremove, unpack, tconcat = select, table.remove, unpack, table.concat
|
local select, tremove, unpack, tconcat = select, table.remove, unpack, table.concat
|
||||||
|
|
||||||
-- WoW APIs
|
-- WoW APIs
|
||||||
local CreateFrame, UIParent = CreateFrame, UIParent
|
local CreateFrame, UIParent = CreateFrame, UIParent
|
||||||
|
|
||||||
-- Global vars/functions that we don't upvalue since they might get hooked, or upgraded
|
|
||||||
-- List them here for Mikk's FindGlobals script
|
|
||||||
-- GLOBALS: FONT_COLOR_CODE_CLOSE
|
|
||||||
|
|
||||||
-- Recycling functions
|
-- Recycling functions
|
||||||
local new, del
|
local new, del
|
||||||
do
|
do
|
||||||
@ -567,7 +563,11 @@ local methods = {
|
|||||||
if maxtreewidth > 100 and status.treewidth > maxtreewidth then
|
if maxtreewidth > 100 and status.treewidth > maxtreewidth then
|
||||||
self:SetTreeWidth(maxtreewidth, status.treesizable)
|
self:SetTreeWidth(maxtreewidth, status.treesizable)
|
||||||
end
|
end
|
||||||
treeframe:SetMaxResize(maxtreewidth, 1600)
|
if treeframe.SetResizeBounds then
|
||||||
|
treeframe:SetResizeBounds(100, 1, maxtreewidth, 1600)
|
||||||
|
else
|
||||||
|
treeframe:SetMaxResize(maxtreewidth, 1600)
|
||||||
|
end
|
||||||
end,
|
end,
|
||||||
|
|
||||||
["OnHeightSet"] = function(self, height)
|
["OnHeightSet"] = function(self, height)
|
||||||
@ -637,7 +637,7 @@ local function Constructor()
|
|||||||
local num = AceGUI:GetNextWidgetNum(Type)
|
local num = AceGUI:GetNextWidgetNum(Type)
|
||||||
local frame = CreateFrame("Frame", nil, UIParent)
|
local frame = CreateFrame("Frame", nil, UIParent)
|
||||||
|
|
||||||
local treeframe = CreateFrame("Frame", nil, frame, BackdropTemplateMixin and "BackdropTemplate" or nil)
|
local treeframe = CreateFrame("Frame", nil, frame, "BackdropTemplate")
|
||||||
treeframe:SetPoint("TOPLEFT")
|
treeframe:SetPoint("TOPLEFT")
|
||||||
treeframe:SetPoint("BOTTOMLEFT")
|
treeframe:SetPoint("BOTTOMLEFT")
|
||||||
treeframe:SetWidth(DEFAULT_TREE_WIDTH)
|
treeframe:SetWidth(DEFAULT_TREE_WIDTH)
|
||||||
@ -646,13 +646,17 @@ local function Constructor()
|
|||||||
treeframe:SetBackdropColor(0.1, 0.1, 0.1, 0.5)
|
treeframe:SetBackdropColor(0.1, 0.1, 0.1, 0.5)
|
||||||
treeframe:SetBackdropBorderColor(0.4, 0.4, 0.4)
|
treeframe:SetBackdropBorderColor(0.4, 0.4, 0.4)
|
||||||
treeframe:SetResizable(true)
|
treeframe:SetResizable(true)
|
||||||
treeframe:SetMinResize(100, 1)
|
if treeframe.SetResizeBounds then -- WoW 10.0
|
||||||
treeframe:SetMaxResize(400, 1600)
|
treeframe:SetResizeBounds(100, 1, 400, 1600)
|
||||||
|
else
|
||||||
|
treeframe:SetMinResize(100, 1)
|
||||||
|
treeframe:SetMaxResize(400, 1600)
|
||||||
|
end
|
||||||
treeframe:SetScript("OnUpdate", FirstFrameUpdate)
|
treeframe:SetScript("OnUpdate", FirstFrameUpdate)
|
||||||
treeframe:SetScript("OnSizeChanged", Tree_OnSizeChanged)
|
treeframe:SetScript("OnSizeChanged", Tree_OnSizeChanged)
|
||||||
treeframe:SetScript("OnMouseWheel", Tree_OnMouseWheel)
|
treeframe:SetScript("OnMouseWheel", Tree_OnMouseWheel)
|
||||||
|
|
||||||
local dragger = CreateFrame("Frame", nil, treeframe, BackdropTemplateMixin and "BackdropTemplate" or nil)
|
local dragger = CreateFrame("Frame", nil, treeframe, "BackdropTemplate")
|
||||||
dragger:SetWidth(8)
|
dragger:SetWidth(8)
|
||||||
dragger:SetPoint("TOP", treeframe, "TOPRIGHT")
|
dragger:SetPoint("TOP", treeframe, "TOPRIGHT")
|
||||||
dragger:SetPoint("BOTTOM", treeframe, "BOTTOMRIGHT")
|
dragger:SetPoint("BOTTOM", treeframe, "BOTTOMRIGHT")
|
||||||
@ -677,7 +681,7 @@ local function Constructor()
|
|||||||
scrollbg:SetAllPoints(scrollbar)
|
scrollbg:SetAllPoints(scrollbar)
|
||||||
scrollbg:SetColorTexture(0,0,0,0.4)
|
scrollbg:SetColorTexture(0,0,0,0.4)
|
||||||
|
|
||||||
local border = CreateFrame("Frame", nil, frame, BackdropTemplateMixin and "BackdropTemplate" or nil)
|
local border = CreateFrame("Frame", nil, frame, "BackdropTemplate")
|
||||||
border:SetPoint("TOPLEFT", treeframe, "TOPRIGHT")
|
border:SetPoint("TOPLEFT", treeframe, "TOPRIGHT")
|
||||||
border:SetPoint("BOTTOMRIGHT")
|
border:SetPoint("BOTTOMRIGHT")
|
||||||
border:SetBackdrop(PaneBackdrop)
|
border:SetBackdrop(PaneBackdrop)
|
||||||
|
@ -7,10 +7,6 @@ local pairs, assert, type = pairs, assert, type
|
|||||||
local PlaySound = PlaySound
|
local PlaySound = PlaySound
|
||||||
local CreateFrame, UIParent = CreateFrame, UIParent
|
local CreateFrame, UIParent = CreateFrame, UIParent
|
||||||
|
|
||||||
-- Global vars/functions that we don't upvalue since they might get hooked, or upgraded
|
|
||||||
-- List them here for Mikk's FindGlobals script
|
|
||||||
-- GLOBALS: GameFontNormal
|
|
||||||
|
|
||||||
----------------
|
----------------
|
||||||
-- Main Frame --
|
-- Main Frame --
|
||||||
----------------
|
----------------
|
||||||
@ -21,7 +17,7 @@ local CreateFrame, UIParent = CreateFrame, UIParent
|
|||||||
]]
|
]]
|
||||||
do
|
do
|
||||||
local Type = "Window"
|
local Type = "Window"
|
||||||
local Version = 6
|
local Version = 8
|
||||||
|
|
||||||
local function frameOnShow(this)
|
local function frameOnShow(this)
|
||||||
this.obj:Fire("OnShow")
|
this.obj:Fire("OnShow")
|
||||||
@ -186,7 +182,11 @@ do
|
|||||||
|
|
||||||
frame:SetScript("OnShow",frameOnShow)
|
frame:SetScript("OnShow",frameOnShow)
|
||||||
frame:SetScript("OnHide",frameOnClose)
|
frame:SetScript("OnHide",frameOnClose)
|
||||||
frame:SetMinResize(240,240)
|
if frame.SetResizeBounds then -- WoW 10.0
|
||||||
|
frame:SetResizeBounds(240,240)
|
||||||
|
else
|
||||||
|
frame:SetMinResize(240,240)
|
||||||
|
end
|
||||||
frame:SetToplevel(true)
|
frame:SetToplevel(true)
|
||||||
|
|
||||||
local titlebg = frame:CreateTexture(nil, "BACKGROUND")
|
local titlebg = frame:CreateTexture(nil, "BACKGROUND")
|
||||||
@ -300,7 +300,7 @@ do
|
|||||||
line2:SetHeight(8)
|
line2:SetHeight(8)
|
||||||
line2:SetPoint("BOTTOMRIGHT", -8, 8)
|
line2:SetPoint("BOTTOMRIGHT", -8, 8)
|
||||||
line2:SetTexture(137057) -- Interface\\Tooltips\\UI-Tooltip-Border
|
line2:SetTexture(137057) -- Interface\\Tooltips\\UI-Tooltip-Border
|
||||||
local x = 0.1 * 8/17
|
x = 0.1 * 8/17
|
||||||
line2:SetTexCoord(0.05 - x, 0.5, 0.05, 0.5 + x, 0.05, 0.5 - x, 0.5 + x, 0.5)
|
line2:SetTexCoord(0.05 - x, 0.5, 0.05, 0.5 + x, 0.05, 0.5 - x, 0.5 + x, 0.5)
|
||||||
|
|
||||||
local sizer_s = CreateFrame("Frame",nil,frame)
|
local sizer_s = CreateFrame("Frame",nil,frame)
|
||||||
|
@ -12,10 +12,6 @@ local select, pairs = select, pairs
|
|||||||
local PlaySound = PlaySound
|
local PlaySound = PlaySound
|
||||||
local CreateFrame, UIParent = CreateFrame, UIParent
|
local CreateFrame, UIParent = CreateFrame, UIParent
|
||||||
|
|
||||||
-- Global vars/functions that we don't upvalue since they might get hooked, or upgraded
|
|
||||||
-- List them here for Mikk's FindGlobals script
|
|
||||||
-- GLOBALS: SetDesaturation, GameFontHighlight
|
|
||||||
|
|
||||||
--[[-----------------------------------------------------------------------------
|
--[[-----------------------------------------------------------------------------
|
||||||
Support functions
|
Support functions
|
||||||
-------------------------------------------------------------------------------]]
|
-------------------------------------------------------------------------------]]
|
||||||
@ -199,14 +195,14 @@ local methods = {
|
|||||||
["SetDescription"] = function(self, desc)
|
["SetDescription"] = function(self, desc)
|
||||||
if desc then
|
if desc then
|
||||||
if not self.desc then
|
if not self.desc then
|
||||||
local desc = self.frame:CreateFontString(nil, "OVERLAY", "GameFontHighlightSmall")
|
local f = self.frame:CreateFontString(nil, "OVERLAY", "GameFontHighlightSmall")
|
||||||
desc:ClearAllPoints()
|
f:ClearAllPoints()
|
||||||
desc:SetPoint("TOPLEFT", self.checkbg, "TOPRIGHT", 5, -21)
|
f:SetPoint("TOPLEFT", self.checkbg, "TOPRIGHT", 5, -21)
|
||||||
desc:SetWidth(self.frame.width - 30)
|
f:SetWidth(self.frame.width - 30)
|
||||||
desc:SetPoint("RIGHT", self.frame, "RIGHT", -30, 0)
|
f:SetPoint("RIGHT", self.frame, "RIGHT", -30, 0)
|
||||||
desc:SetJustifyH("LEFT")
|
f:SetJustifyH("LEFT")
|
||||||
desc:SetJustifyV("TOP")
|
f:SetJustifyV("TOP")
|
||||||
self.desc = desc
|
self.desc = f
|
||||||
end
|
end
|
||||||
self.desc:Show()
|
self.desc:Show()
|
||||||
--self.text:SetFontObject(GameFontNormal)
|
--self.text:SetFontObject(GameFontNormal)
|
||||||
|
@ -11,10 +11,6 @@ local pairs = pairs
|
|||||||
-- WoW APIs
|
-- WoW APIs
|
||||||
local CreateFrame, UIParent = CreateFrame, UIParent
|
local CreateFrame, UIParent = CreateFrame, UIParent
|
||||||
|
|
||||||
-- Global vars/functions that we don't upvalue since they might get hooked, or upgraded
|
|
||||||
-- List them here for Mikk's FindGlobals script
|
|
||||||
-- GLOBALS: ColorPickerFrame, OpacitySliderFrame
|
|
||||||
|
|
||||||
--[[-----------------------------------------------------------------------------
|
--[[-----------------------------------------------------------------------------
|
||||||
Support functions
|
Support functions
|
||||||
-------------------------------------------------------------------------------]]
|
-------------------------------------------------------------------------------]]
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
--[[ $Id: AceGUIWidget-DropDown-Items.lua 1202 2019-05-15 23:11:22Z nevcairiel $ ]]--
|
--[[ $Id: AceGUIWidget-DropDown-Items.lua 1272 2022-08-29 15:56:35Z nevcairiel $ ]]--
|
||||||
|
|
||||||
local AceGUI = LibStub("AceGUI-3.0")
|
local AceGUI = LibStub("AceGUI-3.0")
|
||||||
|
|
||||||
@ -41,7 +41,7 @@ local ItemBase = {
|
|||||||
-- NOTE: The ItemBase version is added to each item's version number
|
-- NOTE: The ItemBase version is added to each item's version number
|
||||||
-- to ensure proper updates on ItemBase changes.
|
-- to ensure proper updates on ItemBase changes.
|
||||||
-- Use at least 1000er steps.
|
-- Use at least 1000er steps.
|
||||||
version = 1000,
|
version = 2000,
|
||||||
counter = 0,
|
counter = 0,
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -178,7 +178,7 @@ function ItemBase.Create(type)
|
|||||||
highlight:Hide()
|
highlight:Hide()
|
||||||
self.highlight = highlight
|
self.highlight = highlight
|
||||||
|
|
||||||
local check = frame:CreateTexture("OVERLAY")
|
local check = frame:CreateTexture(nil, "OVERLAY")
|
||||||
check:SetWidth(16)
|
check:SetWidth(16)
|
||||||
check:SetHeight(16)
|
check:SetHeight(16)
|
||||||
check:SetPoint("LEFT",frame,"LEFT",3,-1)
|
check:SetPoint("LEFT",frame,"LEFT",3,-1)
|
||||||
@ -186,7 +186,7 @@ function ItemBase.Create(type)
|
|||||||
check:Hide()
|
check:Hide()
|
||||||
self.check = check
|
self.check = check
|
||||||
|
|
||||||
local sub = frame:CreateTexture("OVERLAY")
|
local sub = frame:CreateTexture(nil, "OVERLAY")
|
||||||
sub:SetWidth(16)
|
sub:SetWidth(16)
|
||||||
sub:SetHeight(16)
|
sub:SetHeight(16)
|
||||||
sub:SetPoint("RIGHT",frame,"RIGHT",-3,-1)
|
sub:SetPoint("RIGHT",frame,"RIGHT",-3,-1)
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
--[[ $Id: AceGUIWidget-DropDown.lua 1239 2020-09-20 10:22:02Z nevcairiel $ ]]--
|
--[[ $Id: AceGUIWidget-DropDown.lua 1284 2022-09-25 09:15:30Z nevcairiel $ ]]--
|
||||||
local AceGUI = LibStub("AceGUI-3.0")
|
local AceGUI = LibStub("AceGUI-3.0")
|
||||||
|
|
||||||
-- Lua APIs
|
-- Lua APIs
|
||||||
@ -11,10 +11,6 @@ local PlaySound = PlaySound
|
|||||||
local UIParent, CreateFrame = UIParent, CreateFrame
|
local UIParent, CreateFrame = UIParent, CreateFrame
|
||||||
local _G = _G
|
local _G = _G
|
||||||
|
|
||||||
-- Global vars/functions that we don't upvalue since they might get hooked, or upgraded
|
|
||||||
-- List them here for Mikk's FindGlobals script
|
|
||||||
-- GLOBALS: CLOSE
|
|
||||||
|
|
||||||
local function fixlevels(parent,...)
|
local function fixlevels(parent,...)
|
||||||
local i = 1
|
local i = 1
|
||||||
local child = select(i, ...)
|
local child = select(i, ...)
|
||||||
@ -253,7 +249,7 @@ do
|
|||||||
|
|
||||||
local function Constructor()
|
local function Constructor()
|
||||||
local count = AceGUI:GetNextWidgetNum(widgetType)
|
local count = AceGUI:GetNextWidgetNum(widgetType)
|
||||||
local frame = CreateFrame("Frame", "AceGUI30Pullout"..count, UIParent, BackdropTemplateMixin and "BackdropTemplate" or nil)
|
local frame = CreateFrame("Frame", "AceGUI30Pullout"..count, UIParent, "BackdropTemplate")
|
||||||
local self = {}
|
local self = {}
|
||||||
self.count = count
|
self.count = count
|
||||||
self.type = widgetType
|
self.type = widgetType
|
||||||
@ -304,7 +300,7 @@ do
|
|||||||
scrollFrame.obj = self
|
scrollFrame.obj = self
|
||||||
itemFrame.obj = self
|
itemFrame.obj = self
|
||||||
|
|
||||||
local slider = CreateFrame("Slider", "AceGUI30PulloutScrollbar"..count, scrollFrame, BackdropTemplateMixin and "BackdropTemplate" or nil)
|
local slider = CreateFrame("Slider", "AceGUI30PulloutScrollbar"..count, scrollFrame, "BackdropTemplate")
|
||||||
slider:SetOrientation("VERTICAL")
|
slider:SetOrientation("VERTICAL")
|
||||||
slider:SetHitRectInsets(0, 0, -10, 0)
|
slider:SetHitRectInsets(0, 0, -10, 0)
|
||||||
slider:SetBackdrop(sliderBackdrop)
|
slider:SetBackdrop(sliderBackdrop)
|
||||||
@ -351,7 +347,7 @@ end
|
|||||||
|
|
||||||
do
|
do
|
||||||
local widgetType = "Dropdown"
|
local widgetType = "Dropdown"
|
||||||
local widgetVersion = 35
|
local widgetVersion = 36
|
||||||
|
|
||||||
--[[ Static data ]]--
|
--[[ Static data ]]--
|
||||||
|
|
||||||
@ -376,7 +372,6 @@ do
|
|||||||
|
|
||||||
local function Dropdown_TogglePullout(this)
|
local function Dropdown_TogglePullout(this)
|
||||||
local self = this.obj
|
local self = this.obj
|
||||||
PlaySound(856) -- SOUNDKIT.IG_MAINMENU_OPTION_CHECKBOX_ON
|
|
||||||
if self.open then
|
if self.open then
|
||||||
self.open = nil
|
self.open = nil
|
||||||
self.pullout:Close()
|
self.pullout:Close()
|
||||||
|
@ -14,10 +14,6 @@ local GetCursorInfo, ClearCursor, GetSpellInfo = GetCursorInfo, ClearCursor, Get
|
|||||||
local CreateFrame, UIParent = CreateFrame, UIParent
|
local CreateFrame, UIParent = CreateFrame, UIParent
|
||||||
local _G = _G
|
local _G = _G
|
||||||
|
|
||||||
-- Global vars/functions that we don't upvalue since they might get hooked, or upgraded
|
|
||||||
-- List them here for Mikk's FindGlobals script
|
|
||||||
-- GLOBALS: AceGUIEditBoxInsertLink, ChatFontNormal, OKAY
|
|
||||||
|
|
||||||
--[[-----------------------------------------------------------------------------
|
--[[-----------------------------------------------------------------------------
|
||||||
Support functions
|
Support functions
|
||||||
-------------------------------------------------------------------------------]]
|
-------------------------------------------------------------------------------]]
|
||||||
|
@ -13,10 +13,6 @@ local pairs = pairs
|
|||||||
local IsShiftKeyDown, IsControlKeyDown, IsAltKeyDown = IsShiftKeyDown, IsControlKeyDown, IsAltKeyDown
|
local IsShiftKeyDown, IsControlKeyDown, IsAltKeyDown = IsShiftKeyDown, IsControlKeyDown, IsAltKeyDown
|
||||||
local CreateFrame, UIParent = CreateFrame, UIParent
|
local CreateFrame, UIParent = CreateFrame, UIParent
|
||||||
|
|
||||||
-- Global vars/functions that we don't upvalue since they might get hooked, or upgraded
|
|
||||||
-- List them here for Mikk's FindGlobals script
|
|
||||||
-- GLOBALS: NOT_BOUND
|
|
||||||
|
|
||||||
--[[-----------------------------------------------------------------------------
|
--[[-----------------------------------------------------------------------------
|
||||||
Scripts
|
Scripts
|
||||||
-------------------------------------------------------------------------------]]
|
-------------------------------------------------------------------------------]]
|
||||||
@ -214,7 +210,7 @@ local function Constructor()
|
|||||||
label:SetJustifyH("CENTER")
|
label:SetJustifyH("CENTER")
|
||||||
label:SetHeight(18)
|
label:SetHeight(18)
|
||||||
|
|
||||||
local msgframe = CreateFrame("Frame", nil, UIParent, BackdropTemplateMixin and "BackdropTemplate" or nil)
|
local msgframe = CreateFrame("Frame", nil, UIParent, "BackdropTemplate")
|
||||||
msgframe:SetHeight(30)
|
msgframe:SetHeight(30)
|
||||||
msgframe:SetBackdrop(ControlBackdrop)
|
msgframe:SetBackdrop(ControlBackdrop)
|
||||||
msgframe:SetBackdropColor(0,0,0)
|
msgframe:SetBackdropColor(0,0,0)
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
Label Widget
|
Label Widget
|
||||||
Displays text and optionally an icon.
|
Displays text and optionally an icon.
|
||||||
-------------------------------------------------------------------------------]]
|
-------------------------------------------------------------------------------]]
|
||||||
local Type, Version = "Label", 27
|
local Type, Version = "Label", 28
|
||||||
local AceGUI = LibStub and LibStub("AceGUI-3.0", true)
|
local AceGUI = LibStub and LibStub("AceGUI-3.0", true)
|
||||||
if not AceGUI or (AceGUI:GetWidgetVersion(Type) or 0) >= Version then return end
|
if not AceGUI or (AceGUI:GetWidgetVersion(Type) or 0) >= Version then return end
|
||||||
|
|
||||||
@ -12,10 +12,6 @@ local max, select, pairs = math.max, select, pairs
|
|||||||
-- WoW APIs
|
-- WoW APIs
|
||||||
local CreateFrame, UIParent = CreateFrame, UIParent
|
local CreateFrame, UIParent = CreateFrame, UIParent
|
||||||
|
|
||||||
-- Global vars/functions that we don't upvalue since they might get hooked, or upgraded
|
|
||||||
-- List them here for Mikk's FindGlobals script
|
|
||||||
-- GLOBALS: GameFontHighlightSmall
|
|
||||||
|
|
||||||
--[[-----------------------------------------------------------------------------
|
--[[-----------------------------------------------------------------------------
|
||||||
Support functions
|
Support functions
|
||||||
-------------------------------------------------------------------------------]]
|
-------------------------------------------------------------------------------]]
|
||||||
@ -129,12 +125,16 @@ local methods = {
|
|||||||
end,
|
end,
|
||||||
|
|
||||||
["SetFont"] = function(self, font, height, flags)
|
["SetFont"] = function(self, font, height, flags)
|
||||||
self.label:SetFont(font, height, flags)
|
if not self.fontObject then
|
||||||
UpdateImageAnchor(self)
|
self.fontObject = CreateFont("AceGUI30LabelFont" .. AceGUI:GetNextWidgetNum(Type))
|
||||||
|
end
|
||||||
|
self.fontObject:SetFont(font, height, flags)
|
||||||
|
self:SetFontObject(self.fontObject)
|
||||||
end,
|
end,
|
||||||
|
|
||||||
["SetFontObject"] = function(self, font)
|
["SetFontObject"] = function(self, font)
|
||||||
self:SetFont((font or GameFontHighlightSmall):GetFont())
|
self.label:SetFontObject(font or GameFontHighlightSmall)
|
||||||
|
UpdateImageAnchor(self)
|
||||||
end,
|
end,
|
||||||
|
|
||||||
["SetImageSize"] = function(self, width, height)
|
["SetImageSize"] = function(self, width, height)
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
local Type, Version = "MultiLineEditBox", 29
|
local Type, Version = "MultiLineEditBox", 32
|
||||||
local AceGUI = LibStub and LibStub("AceGUI-3.0", true)
|
local AceGUI = LibStub and LibStub("AceGUI-3.0", true)
|
||||||
if not AceGUI or (AceGUI:GetWidgetVersion(Type) or 0) >= Version then return end
|
if not AceGUI or (AceGUI:GetWidgetVersion(Type) or 0) >= Version then return end
|
||||||
|
|
||||||
@ -10,10 +10,6 @@ local GetCursorInfo, GetSpellInfo, ClearCursor = GetCursorInfo, GetSpellInfo, Cl
|
|||||||
local CreateFrame, UIParent = CreateFrame, UIParent
|
local CreateFrame, UIParent = CreateFrame, UIParent
|
||||||
local _G = _G
|
local _G = _G
|
||||||
|
|
||||||
-- Global vars/functions that we don't upvalue since they might get hooked, or upgraded
|
|
||||||
-- List them here for Mikk's FindGlobals script
|
|
||||||
-- GLOBALS: ACCEPT, ChatFontNormal
|
|
||||||
|
|
||||||
--[[-----------------------------------------------------------------------------
|
--[[-----------------------------------------------------------------------------
|
||||||
Support functions
|
Support functions
|
||||||
-------------------------------------------------------------------------------]]
|
-------------------------------------------------------------------------------]]
|
||||||
@ -145,6 +141,14 @@ local function OnVerticalScroll(self, offset)
|
|||||||
editBox:SetHitRectInsets(0, 0, offset, editBox:GetHeight() - offset - self:GetHeight())
|
editBox:SetHitRectInsets(0, 0, offset, editBox:GetHeight() - offset - self:GetHeight())
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function OnScrollRangeChanged(self, xrange, yrange)
|
||||||
|
if yrange == 0 then
|
||||||
|
self.obj.editBox:SetHitRectInsets(0, 0, 0, 0)
|
||||||
|
else
|
||||||
|
OnVerticalScroll(self, self:GetVerticalScroll())
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
local function OnShowFocus(frame)
|
local function OnShowFocus(frame)
|
||||||
frame.obj.editBox:SetFocus()
|
frame.obj.editBox:SetFocus()
|
||||||
frame:SetScript("OnShow", nil)
|
frame:SetScript("OnShow", nil)
|
||||||
@ -257,8 +261,6 @@ local methods = {
|
|||||||
["SetCursorPosition"] = function(self, ...)
|
["SetCursorPosition"] = function(self, ...)
|
||||||
return self.editBox:SetCursorPosition(...)
|
return self.editBox:SetCursorPosition(...)
|
||||||
end,
|
end,
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
--[[-----------------------------------------------------------------------------
|
--[[-----------------------------------------------------------------------------
|
||||||
@ -297,7 +299,7 @@ local function Constructor()
|
|||||||
text:SetPoint("BOTTOMRIGHT", button, "BOTTOMRIGHT", -5, 1)
|
text:SetPoint("BOTTOMRIGHT", button, "BOTTOMRIGHT", -5, 1)
|
||||||
text:SetJustifyV("MIDDLE")
|
text:SetJustifyV("MIDDLE")
|
||||||
|
|
||||||
local scrollBG = CreateFrame("Frame", nil, frame, BackdropTemplateMixin and "BackdropTemplate" or nil)
|
local scrollBG = CreateFrame("Frame", nil, frame, "BackdropTemplate")
|
||||||
scrollBG:SetBackdrop(backdrop)
|
scrollBG:SetBackdrop(backdrop)
|
||||||
scrollBG:SetBackdropColor(0, 0, 0)
|
scrollBG:SetBackdropColor(0, 0, 0)
|
||||||
scrollBG:SetBackdropBorderColor(0.4, 0.4, 0.4)
|
scrollBG:SetBackdropBorderColor(0.4, 0.4, 0.4)
|
||||||
@ -321,6 +323,7 @@ local function Constructor()
|
|||||||
scrollFrame:SetScript("OnReceiveDrag", OnReceiveDrag)
|
scrollFrame:SetScript("OnReceiveDrag", OnReceiveDrag)
|
||||||
scrollFrame:SetScript("OnSizeChanged", OnSizeChanged)
|
scrollFrame:SetScript("OnSizeChanged", OnSizeChanged)
|
||||||
scrollFrame:HookScript("OnVerticalScroll", OnVerticalScroll)
|
scrollFrame:HookScript("OnVerticalScroll", OnVerticalScroll)
|
||||||
|
scrollFrame:HookScript("OnScrollRangeChanged", OnScrollRangeChanged)
|
||||||
|
|
||||||
local editBox = CreateFrame("EditBox", ("%s%dEdit"):format(Type, widgetNum), scrollFrame)
|
local editBox = CreateFrame("EditBox", ("%s%dEdit"):format(Type, widgetNum), scrollFrame)
|
||||||
editBox:SetAllPoints()
|
editBox:SetAllPoints()
|
||||||
|
@ -14,10 +14,6 @@ local tonumber, pairs = tonumber, pairs
|
|||||||
local PlaySound = PlaySound
|
local PlaySound = PlaySound
|
||||||
local CreateFrame, UIParent = CreateFrame, UIParent
|
local CreateFrame, UIParent = CreateFrame, UIParent
|
||||||
|
|
||||||
-- Global vars/functions that we don't upvalue since they might get hooked, or upgraded
|
|
||||||
-- List them here for Mikk's FindGlobals script
|
|
||||||
-- GLOBALS: GameFontHighlightSmall
|
|
||||||
|
|
||||||
--[[-----------------------------------------------------------------------------
|
--[[-----------------------------------------------------------------------------
|
||||||
Support functions
|
Support functions
|
||||||
-------------------------------------------------------------------------------]]
|
-------------------------------------------------------------------------------]]
|
||||||
@ -31,13 +27,13 @@ local function UpdateText(self)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function UpdateLabels(self)
|
local function UpdateLabels(self)
|
||||||
local min, max = (self.min or 0), (self.max or 100)
|
local min_value, max_value = (self.min or 0), (self.max or 100)
|
||||||
if self.ispercent then
|
if self.ispercent then
|
||||||
self.lowtext:SetFormattedText("%s%%", (min * 100))
|
self.lowtext:SetFormattedText("%s%%", (min_value * 100))
|
||||||
self.hightext:SetFormattedText("%s%%", (max * 100))
|
self.hightext:SetFormattedText("%s%%", (max_value * 100))
|
||||||
else
|
else
|
||||||
self.lowtext:SetText(min)
|
self.lowtext:SetText(min_value)
|
||||||
self.hightext:SetText(max)
|
self.hightext:SetText(max_value)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -175,13 +171,13 @@ local methods = {
|
|||||||
self.label:SetText(text)
|
self.label:SetText(text)
|
||||||
end,
|
end,
|
||||||
|
|
||||||
["SetSliderValues"] = function(self, min, max, step)
|
["SetSliderValues"] = function(self, min_value, max_value, step)
|
||||||
local frame = self.slider
|
local frame = self.slider
|
||||||
frame.setup = true
|
frame.setup = true
|
||||||
self.min = min
|
self.min = min_value
|
||||||
self.max = max
|
self.max = max_value
|
||||||
self.step = step
|
self.step = step
|
||||||
frame:SetMinMaxValues(min or 0,max or 100)
|
frame:SetMinMaxValues(min_value or 0,max_value or 100)
|
||||||
UpdateLabels(self)
|
UpdateLabels(self)
|
||||||
frame:SetValueStep(step or 1)
|
frame:SetValueStep(step or 1)
|
||||||
if self.value then
|
if self.value then
|
||||||
@ -225,7 +221,7 @@ local function Constructor()
|
|||||||
label:SetJustifyH("CENTER")
|
label:SetJustifyH("CENTER")
|
||||||
label:SetHeight(15)
|
label:SetHeight(15)
|
||||||
|
|
||||||
local slider = CreateFrame("Slider", nil, frame, BackdropTemplateMixin and "BackdropTemplate" or nil)
|
local slider = CreateFrame("Slider", nil, frame, "BackdropTemplate")
|
||||||
slider:SetOrientation("HORIZONTAL")
|
slider:SetOrientation("HORIZONTAL")
|
||||||
slider:SetHeight(15)
|
slider:SetHeight(15)
|
||||||
slider:SetHitRectInsets(0, 0, -10, 0)
|
slider:SetHitRectInsets(0, 0, -10, 0)
|
||||||
@ -247,7 +243,7 @@ local function Constructor()
|
|||||||
local hightext = slider:CreateFontString(nil, "ARTWORK", "GameFontHighlightSmall")
|
local hightext = slider:CreateFontString(nil, "ARTWORK", "GameFontHighlightSmall")
|
||||||
hightext:SetPoint("TOPRIGHT", slider, "BOTTOMRIGHT", -2, 3)
|
hightext:SetPoint("TOPRIGHT", slider, "BOTTOMRIGHT", -2, 3)
|
||||||
|
|
||||||
local editbox = CreateFrame("EditBox", nil, frame, BackdropTemplateMixin and "BackdropTemplate" or nil)
|
local editbox = CreateFrame("EditBox", nil, frame, "BackdropTemplate")
|
||||||
editbox:SetAutoFocus(false)
|
editbox:SetAutoFocus(false)
|
||||||
editbox:SetFontObject(GameFontHighlightSmall)
|
editbox:SetFontObject(GameFontHighlightSmall)
|
||||||
editbox:SetPoint("TOP", slider, "BOTTOM")
|
editbox:SetPoint("TOP", slider, "BOTTOM")
|
||||||
|
@ -9,8 +9,8 @@
|
|||||||
-- make into AceHook.
|
-- make into AceHook.
|
||||||
-- @class file
|
-- @class file
|
||||||
-- @name AceHook-3.0
|
-- @name AceHook-3.0
|
||||||
-- @release $Id: AceHook-3.0.lua 1202 2019-05-15 23:11:22Z nevcairiel $
|
-- @release $Id: AceHook-3.0.lua 1284 2022-09-25 09:15:30Z nevcairiel $
|
||||||
local ACEHOOK_MAJOR, ACEHOOK_MINOR = "AceHook-3.0", 8
|
local ACEHOOK_MAJOR, ACEHOOK_MINOR = "AceHook-3.0", 9
|
||||||
local AceHook, oldminor = LibStub:NewLibrary(ACEHOOK_MAJOR, ACEHOOK_MINOR)
|
local AceHook, oldminor = LibStub:NewLibrary(ACEHOOK_MAJOR, ACEHOOK_MINOR)
|
||||||
|
|
||||||
if not AceHook then return end -- No upgrade needed
|
if not AceHook then return end -- No upgrade needed
|
||||||
@ -195,7 +195,6 @@ function hook(self, obj, method, handler, script, secure, raw, forceSecure, usag
|
|||||||
registry[self][method] = nil
|
registry[self][method] = nil
|
||||||
end
|
end
|
||||||
handlers[uid], actives[uid], scripts[uid] = nil, nil, nil
|
handlers[uid], actives[uid], scripts[uid] = nil, nil, nil
|
||||||
uid = nil
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local orig
|
local orig
|
||||||
@ -478,10 +477,10 @@ function AceHook:UnhookAll()
|
|||||||
for key, value in pairs(registry[self]) do
|
for key, value in pairs(registry[self]) do
|
||||||
if type(key) == "table" then
|
if type(key) == "table" then
|
||||||
for method in pairs(value) do
|
for method in pairs(value) do
|
||||||
self:Unhook(key, method)
|
AceHook.Unhook(self, key, method)
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
self:Unhook(key)
|
AceHook.Unhook(self, key)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -10,7 +10,7 @@
|
|||||||
-- make into AceSerializer.
|
-- make into AceSerializer.
|
||||||
-- @class file
|
-- @class file
|
||||||
-- @name AceSerializer-3.0
|
-- @name AceSerializer-3.0
|
||||||
-- @release $Id: AceSerializer-3.0.lua 1202 2019-05-15 23:11:22Z nevcairiel $
|
-- @release $Id: AceSerializer-3.0.lua 1284 2022-09-25 09:15:30Z nevcairiel $
|
||||||
local MAJOR,MINOR = "AceSerializer-3.0", 5
|
local MAJOR,MINOR = "AceSerializer-3.0", 5
|
||||||
local AceSerializer, oldminor = LibStub:NewLibrary(MAJOR, MINOR)
|
local AceSerializer, oldminor = LibStub:NewLibrary(MAJOR, MINOR)
|
||||||
|
|
||||||
@ -83,9 +83,9 @@ local function SerializeValue(v, res, nres)
|
|||||||
elseif t=="table" then -- ^T...^t = table (list of key,value pairs)
|
elseif t=="table" then -- ^T...^t = table (list of key,value pairs)
|
||||||
nres=nres+1
|
nres=nres+1
|
||||||
res[nres] = "^T"
|
res[nres] = "^T"
|
||||||
for k,v in pairs(v) do
|
for key,value in pairs(v) do
|
||||||
nres = SerializeValue(k, res, nres)
|
nres = SerializeValue(key, res, nres)
|
||||||
nres = SerializeValue(v, res, nres)
|
nres = SerializeValue(value, res, nres)
|
||||||
end
|
end
|
||||||
nres=nres+1
|
nres=nres+1
|
||||||
res[nres] = "^t"
|
res[nres] = "^t"
|
||||||
|
@ -15,7 +15,7 @@
|
|||||||
-- make into AceTimer.
|
-- make into AceTimer.
|
||||||
-- @class file
|
-- @class file
|
||||||
-- @name AceTimer-3.0
|
-- @name AceTimer-3.0
|
||||||
-- @release $Id: AceTimer-3.0.lua 1202 2019-05-15 23:11:22Z nevcairiel $
|
-- @release $Id: AceTimer-3.0.lua 1284 2022-09-25 09:15:30Z nevcairiel $
|
||||||
|
|
||||||
local MAJOR, MINOR = "AceTimer-3.0", 17 -- Bump minor on changes
|
local MAJOR, MINOR = "AceTimer-3.0", 17 -- Bump minor on changes
|
||||||
local AceTimer, oldminor = LibStub:NewLibrary(MAJOR, MINOR)
|
local AceTimer, oldminor = LibStub:NewLibrary(MAJOR, MINOR)
|
||||||
@ -61,11 +61,11 @@ local function new(self, loop, func, delay, ...)
|
|||||||
-- Compensate delay to get a perfect average delay, even if individual times don't match up perfectly
|
-- Compensate delay to get a perfect average delay, even if individual times don't match up perfectly
|
||||||
-- due to fps differences
|
-- due to fps differences
|
||||||
local time = GetTime()
|
local time = GetTime()
|
||||||
local delay = timer.delay - (time - timer.ends)
|
local ndelay = timer.delay - (time - timer.ends)
|
||||||
-- Ensure the delay doesn't go below the threshold
|
-- Ensure the delay doesn't go below the threshold
|
||||||
if delay < 0.01 then delay = 0.01 end
|
if ndelay < 0.01 then ndelay = 0.01 end
|
||||||
C_TimerAfter(delay, timer.callback)
|
C_TimerAfter(ndelay, timer.callback)
|
||||||
timer.ends = time + delay
|
timer.ends = time + ndelay
|
||||||
else
|
else
|
||||||
activeTimers[timer.handle or timer] = nil
|
activeTimers[timer.handle or timer] = nil
|
||||||
end
|
end
|
||||||
|
@ -1,61 +1,26 @@
|
|||||||
--[[ $Id: CallbackHandler-1.0.lua 3 2008-09-29 16:54:20Z nevcairiel $ ]]
|
--[[ $Id: CallbackHandler-1.0.lua 1298 2022-12-12 15:10:10Z nevcairiel $ ]]
|
||||||
local MAJOR, MINOR = "CallbackHandler-1.0", 3
|
local MAJOR, MINOR = "CallbackHandler-1.0", 8
|
||||||
local CallbackHandler = LibStub:NewLibrary(MAJOR, MINOR)
|
local CallbackHandler = LibStub:NewLibrary(MAJOR, MINOR)
|
||||||
|
|
||||||
if not CallbackHandler then return end -- No upgrade needed
|
if not CallbackHandler then return end -- No upgrade needed
|
||||||
|
|
||||||
local meta = {__index = function(tbl, key) tbl[key] = {} return tbl[key] end}
|
local meta = {__index = function(tbl, key) tbl[key] = {} return tbl[key] end}
|
||||||
|
|
||||||
local type = type
|
-- Lua APIs
|
||||||
local pcall = pcall
|
local securecallfunction, error = securecallfunction, error
|
||||||
local pairs = pairs
|
local setmetatable, rawget = setmetatable, rawget
|
||||||
local assert = assert
|
local next, select, pairs, type, tostring = next, select, pairs, type, tostring
|
||||||
local concat = table.concat
|
|
||||||
local loadstring = loadstring
|
|
||||||
local next = next
|
|
||||||
local select = select
|
|
||||||
local type = type
|
|
||||||
local xpcall = xpcall
|
|
||||||
|
|
||||||
local function errorhandler(err)
|
|
||||||
return geterrorhandler()(err)
|
local function Dispatch(handlers, ...)
|
||||||
|
local index, method = next(handlers)
|
||||||
|
if not method then return end
|
||||||
|
repeat
|
||||||
|
securecallfunction(method, ...)
|
||||||
|
index, method = next(handlers, index)
|
||||||
|
until not method
|
||||||
end
|
end
|
||||||
|
|
||||||
local function CreateDispatcher(argCount)
|
|
||||||
local code = [[
|
|
||||||
local next, xpcall, eh = ...
|
|
||||||
|
|
||||||
local method, ARGS
|
|
||||||
local function call() method(ARGS) end
|
|
||||||
|
|
||||||
local function dispatch(handlers, ...)
|
|
||||||
local index
|
|
||||||
index, method = next(handlers)
|
|
||||||
if not method then return end
|
|
||||||
local OLD_ARGS = ARGS
|
|
||||||
ARGS = ...
|
|
||||||
repeat
|
|
||||||
xpcall(call, eh)
|
|
||||||
index, method = next(handlers, index)
|
|
||||||
until not method
|
|
||||||
ARGS = OLD_ARGS
|
|
||||||
end
|
|
||||||
|
|
||||||
return dispatch
|
|
||||||
]]
|
|
||||||
|
|
||||||
local ARGS, OLD_ARGS = {}, {}
|
|
||||||
for i = 1, argCount do ARGS[i], OLD_ARGS[i] = "arg"..i, "old_arg"..i end
|
|
||||||
code = code:gsub("OLD_ARGS", concat(OLD_ARGS, ", ")):gsub("ARGS", concat(ARGS, ", "))
|
|
||||||
return assert(loadstring(code, "safecall Dispatcher["..argCount.."]"))(next, xpcall, errorhandler)
|
|
||||||
end
|
|
||||||
|
|
||||||
local Dispatchers = setmetatable({}, {__index=function(self, argCount)
|
|
||||||
local dispatcher = CreateDispatcher(argCount)
|
|
||||||
rawset(self, argCount, dispatcher)
|
|
||||||
return dispatcher
|
|
||||||
end})
|
|
||||||
|
|
||||||
--------------------------------------------------------------------------
|
--------------------------------------------------------------------------
|
||||||
-- CallbackHandler:New
|
-- CallbackHandler:New
|
||||||
--
|
--
|
||||||
@ -64,9 +29,7 @@ end})
|
|||||||
-- UnregisterName - name of the callback unregistration API, default "UnregisterCallback"
|
-- UnregisterName - name of the callback unregistration API, default "UnregisterCallback"
|
||||||
-- UnregisterAllName - name of the API to unregister all callbacks, default "UnregisterAllCallbacks". false == don't publish this API.
|
-- UnregisterAllName - name of the API to unregister all callbacks, default "UnregisterAllCallbacks". false == don't publish this API.
|
||||||
|
|
||||||
function CallbackHandler:New(target, RegisterName, UnregisterName, UnregisterAllName, OnUsed, OnUnused)
|
function CallbackHandler.New(_self, target, RegisterName, UnregisterName, UnregisterAllName)
|
||||||
-- TODO: Remove this after beta has gone out
|
|
||||||
assert(not OnUsed and not OnUnused, "ACE-80: OnUsed/OnUnused are deprecated. Callbacks are now done to registry.OnUsed and registry.OnUnused")
|
|
||||||
|
|
||||||
RegisterName = RegisterName or "RegisterCallback"
|
RegisterName = RegisterName or "RegisterCallback"
|
||||||
UnregisterName = UnregisterName or "UnregisterCallback"
|
UnregisterName = UnregisterName or "UnregisterCallback"
|
||||||
@ -88,19 +51,19 @@ function CallbackHandler:New(target, RegisterName, UnregisterName, UnregisterAll
|
|||||||
local oldrecurse = registry.recurse
|
local oldrecurse = registry.recurse
|
||||||
registry.recurse = oldrecurse + 1
|
registry.recurse = oldrecurse + 1
|
||||||
|
|
||||||
Dispatchers[select('#', ...) + 1](events[eventname], eventname, ...)
|
Dispatch(events[eventname], eventname, ...)
|
||||||
|
|
||||||
registry.recurse = oldrecurse
|
registry.recurse = oldrecurse
|
||||||
|
|
||||||
if registry.insertQueue and oldrecurse==0 then
|
if registry.insertQueue and oldrecurse==0 then
|
||||||
-- Something in one of our callbacks wanted to register more callbacks; they got queued
|
-- Something in one of our callbacks wanted to register more callbacks; they got queued
|
||||||
for eventname,callbacks in pairs(registry.insertQueue) do
|
for event,callbacks in pairs(registry.insertQueue) do
|
||||||
local first = not rawget(events, eventname) or not next(events[eventname]) -- test for empty before. not test for one member after. that one member may have been overwritten.
|
local first = not rawget(events, event) or not next(events[event]) -- test for empty before. not test for one member after. that one member may have been overwritten.
|
||||||
for self,func in pairs(callbacks) do
|
for object,func in pairs(callbacks) do
|
||||||
events[eventname][self] = func
|
events[event][object] = func
|
||||||
-- fire OnUsed callback?
|
-- fire OnUsed callback?
|
||||||
if first and registry.OnUsed then
|
if first and registry.OnUsed then
|
||||||
registry.OnUsed(registry, target, eventname)
|
registry.OnUsed(registry, target, event)
|
||||||
first = nil
|
first = nil
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -146,9 +109,9 @@ function CallbackHandler:New(target, RegisterName, UnregisterName, UnregisterAll
|
|||||||
regfunc = function(...) self[method](self,...) end
|
regfunc = function(...) self[method](self,...) end
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
-- function ref with self=object or self="addonId"
|
-- function ref with self=object or self="addonId" or self=thread
|
||||||
if type(self)~="table" and type(self)~="string" then
|
if type(self)~="table" and type(self)~="string" and type(self)~="thread" then
|
||||||
error("Usage: "..RegisterName.."(self or \"addonId\", eventname, method): 'self or addonId': table or string expected.", 2)
|
error("Usage: "..RegisterName.."(self or \"addonId\", eventname, method): 'self or addonId': table or string or thread expected.", 2)
|
||||||
end
|
end
|
||||||
|
|
||||||
if select("#",...)>=1 then -- this is not the same as testing for arg==nil!
|
if select("#",...)>=1 then -- this is not the same as testing for arg==nil!
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<Ui xmlns="http://www.blizzard.com/wow/ui/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.blizzard.com/wow/ui/
|
<Ui xmlns="http://www.blizzard.com/wow/ui/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.blizzard.com/wow/ui/
|
||||||
..\FrameXML\UI.xsd">
|
..\FrameXML\UI.xsd">
|
||||||
<Script file="CallbackHandler-1.0.lua"/>
|
<Script file="CallbackHandler-1.0.lua"/>
|
||||||
</Ui>
|
</Ui>
|
||||||
|
@ -9,7 +9,7 @@ License: MIT
|
|||||||
|
|
||||||
--- DRList-1.0
|
--- DRList-1.0
|
||||||
-- @module DRList-1.0
|
-- @module DRList-1.0
|
||||||
local MAJOR, MINOR = "DRList-1.0", 40 -- Don't forget to change this in Spells.lua aswell!
|
local MAJOR, MINOR = "DRList-1.0", 54 -- Don't forget to change this in Spells.lua aswell!
|
||||||
local Lib = assert(LibStub, MAJOR .. " requires LibStub."):NewLibrary(MAJOR, MINOR)
|
local Lib = assert(LibStub, MAJOR .. " requires LibStub."):NewLibrary(MAJOR, MINOR)
|
||||||
if not Lib then return end -- already loaded
|
if not Lib then return end -- already loaded
|
||||||
|
|
||||||
@ -30,7 +30,7 @@ L["TAUNTS"] = "Taunts"
|
|||||||
L["FEARS"] = "Fears"
|
L["FEARS"] = "Fears"
|
||||||
L["RANDOM_ROOTS"] = "Random roots"
|
L["RANDOM_ROOTS"] = "Random roots"
|
||||||
L["RANDOM_STUNS"] = "Random stuns"
|
L["RANDOM_STUNS"] = "Random stuns"
|
||||||
L["OPENER_STUN"] = "Opener Stuns"
|
L["OPENER_STUN"] = "Opener stuns"
|
||||||
L["HORROR"] = "Horrors"
|
L["HORROR"] = "Horrors"
|
||||||
L["SCATTERS"] = "Scatters"
|
L["SCATTERS"] = "Scatters"
|
||||||
L["SLEEPS"] = GetSpellInfo(1090) or "Sleep"
|
L["SLEEPS"] = GetSpellInfo(1090) or "Sleep"
|
||||||
@ -129,34 +129,30 @@ Lib.gameExpansion = ({
|
|||||||
[WOW_PROJECT_MAINLINE] = "retail",
|
[WOW_PROJECT_MAINLINE] = "retail",
|
||||||
[WOW_PROJECT_CLASSIC] = "classic",
|
[WOW_PROJECT_CLASSIC] = "classic",
|
||||||
[WOW_PROJECT_BURNING_CRUSADE_CLASSIC or 5] = "tbc",
|
[WOW_PROJECT_BURNING_CRUSADE_CLASSIC or 5] = "tbc",
|
||||||
|
[WOW_PROJECT_WRATH_CLASSIC or 11] = "wotlk",
|
||||||
})[WOW_PROJECT_ID]
|
})[WOW_PROJECT_ID]
|
||||||
|
|
||||||
local tocVersion = select(4, GetBuildInfo())
|
|
||||||
if tocVersion >= 30400 and tocVersion < 40000 then
|
|
||||||
Lib.gameExpansion = "wotlk" -- temporary check for wotlk build until new constant is added
|
|
||||||
end
|
|
||||||
|
|
||||||
-- How long it takes for a DR to expire, in seconds.
|
-- How long it takes for a DR to expire, in seconds.
|
||||||
Lib.resetTimes = {
|
Lib.resetTimes = {
|
||||||
retail = {
|
retail = {
|
||||||
["default"] = 18.5, -- 18 sec + 0.5 latency
|
["default"] = 18.5, -- static 18 sec + 0.5 latency
|
||||||
["npc"] = 23, -- Against mobs it seems to last slightly longer, depending on server load
|
["npc"] = 21, -- Against mobs it seems to last slightly longer, depending on server load
|
||||||
["knockback"] = 10, -- Knockbacks are immediately immune and only DRs for 10s
|
["knockback"] = 10.5, -- Knockbacks are immediately immune and only DRs for 10s
|
||||||
},
|
},
|
||||||
|
|
||||||
classic = {
|
classic = {
|
||||||
["default"] = 19, -- dynamic between 15 and 20s
|
["default"] = 20, -- dynamic between 15 and 20s
|
||||||
["npc"] = 23,
|
["npc"] = 21,
|
||||||
},
|
},
|
||||||
|
|
||||||
tbc = {
|
tbc = {
|
||||||
["default"] = 19, -- dynamic between 15 and 20s
|
["default"] = 20, -- dynamic between 15 and 20s
|
||||||
["npc"] = 23,
|
["npc"] = 21,
|
||||||
},
|
},
|
||||||
|
|
||||||
wotlk = {
|
wotlk = {
|
||||||
["default"] = 19, -- dynamic between 15 and 20s
|
["default"] = 20, -- dynamic between 15 and 20s
|
||||||
["npc"] = 23,
|
["npc"] = 21,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -203,7 +199,7 @@ Lib.categoryNames = {
|
|||||||
["counterattack"] = L.COUNTERATTACK,
|
["counterattack"] = L.COUNTERATTACK,
|
||||||
},
|
},
|
||||||
|
|
||||||
wotlk = { -- WORK IN PROGRESS
|
wotlk = {
|
||||||
["incapacitate"] = L.INCAPACITATES,
|
["incapacitate"] = L.INCAPACITATES,
|
||||||
["stun"] = L.STUNS,
|
["stun"] = L.STUNS,
|
||||||
["random_stun"] = L.RANDOM_STUNS,
|
["random_stun"] = L.RANDOM_STUNS,
|
||||||
@ -223,13 +219,12 @@ Lib.categoryNames = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
-- Categories that have DR against normal mobs.
|
-- Categories that have DR against normal mobs.
|
||||||
-- Note that this is only for normal mobs on retail. Special mobs or pets have DR on all categories,
|
-- Note that for retail some special mobs have DR on all categories,
|
||||||
-- see UnitClassification() and UnitIsQuestBoss().
|
-- see UnitClassification() and UnitIsQuestBoss().
|
||||||
Lib.categoriesPvE = {
|
Lib.categoriesPvE = {
|
||||||
retail = {
|
retail = {
|
||||||
["taunt"] = L.TAUNTS, -- Lib.categoryNames.retail.taunt
|
["taunt"] = L.TAUNTS,
|
||||||
["stun"] = L.STUNS,
|
["stun"] = L.STUNS,
|
||||||
["root"] = L.ROOTS,
|
|
||||||
},
|
},
|
||||||
|
|
||||||
classic = {
|
classic = {
|
||||||
@ -296,9 +291,9 @@ function Lib:GetCategories()
|
|||||||
return Lib.categoryNames[Lib.gameExpansion]
|
return Lib.categoryNames[Lib.gameExpansion]
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Get table of all categories that DRs in PvE only.
|
--- Get table of all categories that DRs in PvE.
|
||||||
-- Key is unlocalized name used for API functions, value is localized name used for UI.
|
-- Key is unlocalized name used for API functions, value is localized name used for UI.
|
||||||
-- Note that this is only for normal mobs on retail. Special mobs or pets have DR on all categories,
|
-- Note that for retail some special mobs have DR on all categories,
|
||||||
-- see UnitClassification() and UnitIsQuestBoss().
|
-- see UnitClassification() and UnitIsQuestBoss().
|
||||||
-- Tip: you can combine :GetPvECategories() and :IterateSpellsByCategory() to get spellIDs only for PvE aswell.
|
-- Tip: you can combine :GetPvECategories() and :IterateSpellsByCategory() to get spellIDs only for PvE aswell.
|
||||||
-- @treturn table {string=string}
|
-- @treturn table {string=string}
|
||||||
@ -341,7 +336,7 @@ function Lib:GetCategoryLocalization(category)
|
|||||||
end
|
end
|
||||||
|
|
||||||
--- Check if a category has DR against mobs.
|
--- Check if a category has DR against mobs.
|
||||||
-- Note that this is only for normal mobs on retail. Special mobs or pets have DR on all categories,
|
-- Note that for retail some special mobs have DR on all categories, you need to check for this yourself;
|
||||||
-- see UnitClassification() and UnitIsQuestBoss().
|
-- see UnitClassification() and UnitIsQuestBoss().
|
||||||
-- @tparam string category Unlocalized category name
|
-- @tparam string category Unlocalized category name
|
||||||
-- @treturn bool
|
-- @treturn bool
|
||||||
@ -382,7 +377,6 @@ do
|
|||||||
--- Iterate through the spells of a given category.
|
--- Iterate through the spells of a given category.
|
||||||
-- @tparam string category Unlocalized category name
|
-- @tparam string category Unlocalized category name
|
||||||
-- @usage for spellID in DRList:IterateSpellsByCategory("root") do print(spellID) end
|
-- @usage for spellID in DRList:IterateSpellsByCategory("root") do print(spellID) end
|
||||||
-- @warning Slow function, do not use for frequent combat related stuff unless you cache results.
|
|
||||||
-- @return Iterator function
|
-- @return Iterator function
|
||||||
function Lib:IterateSpellsByCategory(category)
|
function Lib:IterateSpellsByCategory(category)
|
||||||
assert(Lib.categoryNames[Lib.gameExpansion][category], "invalid category")
|
assert(Lib.categoryNames[Lib.gameExpansion][category], "invalid category")
|
||||||
@ -395,6 +389,6 @@ Lib.GetCategoryName = Lib.GetCategoryLocalization
|
|||||||
Lib.IsPVE = Lib.IsPvECategory
|
Lib.IsPVE = Lib.IsPvECategory
|
||||||
Lib.NextDR = Lib.GetNextDR
|
Lib.NextDR = Lib.GetNextDR
|
||||||
Lib.GetSpellCategory = Lib.GetCategoryBySpellID
|
Lib.GetSpellCategory = Lib.GetCategoryBySpellID
|
||||||
Lib.IterateSpells = Lib.IterateSpellsByCategory
|
|
||||||
Lib.RESET_TIME = Lib.resetTimes[Lib.gameExpansion].default
|
Lib.RESET_TIME = Lib.resetTimes[Lib.gameExpansion].default
|
||||||
Lib.pveDR = Lib.categoriesPvE
|
Lib.pveDR = Lib.categoriesPvE
|
||||||
|
Lib.IterateSpells = function(cat) if cat then return Lib.IterateSpellsByCategory(cat) else return next, Lib.spellList end end
|
||||||
|
@ -1,7 +1,8 @@
|
|||||||
## Interface: 90205
|
## Interface: 100105
|
||||||
## Interface-Classic: 11402
|
## Interface-Classic: 11403
|
||||||
## Interface-BCC: 20504
|
## Interface-BCC: 20504
|
||||||
## Interface-Wrath: 30400
|
## Interface-Wrath: 30402
|
||||||
|
## IconTexture: Interface\Icons\Spell_nature_heavypolymorph1
|
||||||
## Title: Lib: DRList-1.0
|
## Title: Lib: DRList-1.0
|
||||||
## Version: @project-version@
|
## Version: @project-version@
|
||||||
## X-Category: Library
|
## X-Category: Library
|
||||||
@ -14,6 +15,7 @@ libs\LibStub\LibStub.lua
|
|||||||
#@end-no-lib-strip@
|
#@end-no-lib-strip@
|
||||||
|
|
||||||
DRList-1.0.xml
|
DRList-1.0.xml
|
||||||
|
|
||||||
#@do-not-package@
|
#@do-not-package@
|
||||||
tests\engine.lua
|
tests\engine.lua
|
||||||
tests\test-retail.lua
|
tests\test-retail.lua
|
||||||
|
@ -1,5 +1,10 @@
|
|||||||
local Lib, version = LibStub("DRList-1.0")
|
local MAJOR, MINOR = "DRList-1.0", 54 -- Don't forget to change this in DRList-1.0.lua aswell!
|
||||||
if Lib.spellList and version >= 40 then return end
|
local Lib = LibStub(MAJOR)
|
||||||
|
if Lib.spellListVersion and Lib.spellListVersion >= MINOR then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
Lib.spellListVersion = MINOR
|
||||||
|
|
||||||
if Lib.gameExpansion == "retail" then
|
if Lib.gameExpansion == "retail" then
|
||||||
|
|
||||||
@ -8,17 +13,20 @@ if Lib.gameExpansion == "retail" then
|
|||||||
[207167] = "disorient", -- Blinding Sleet
|
[207167] = "disorient", -- Blinding Sleet
|
||||||
[207685] = "disorient", -- Sigil of Misery
|
[207685] = "disorient", -- Sigil of Misery
|
||||||
[33786] = "disorient", -- Cyclone
|
[33786] = "disorient", -- Cyclone
|
||||||
|
[360806] = "disorient", -- Sleep Walk
|
||||||
[1513] = "disorient", -- Scare Beast
|
[1513] = "disorient", -- Scare Beast
|
||||||
[31661] = "disorient", -- Dragon's Breath
|
[31661] = "disorient", -- Dragon's Breath
|
||||||
[198909] = "disorient", -- Song of Chi-ji
|
[198909] = "disorient", -- Song of Chi-ji
|
||||||
[202274] = "disorient", -- Incendiary Brew
|
[202274] = "disorient", -- Hot Trub
|
||||||
[105421] = "disorient", -- Blinding Light
|
[105421] = "disorient", -- Blinding Light
|
||||||
[10326] = "disorient", -- Turn Evil
|
[10326] = "disorient", -- Turn Evil
|
||||||
|
[205364] = "disorient", -- Dominate Mind
|
||||||
[605] = "disorient", -- Mind Control
|
[605] = "disorient", -- Mind Control
|
||||||
[8122] = "disorient", -- Psychic Scream
|
[8122] = "disorient", -- Psychic Scream
|
||||||
[226943] = "disorient", -- Mind Bomb
|
[226943] = "disorient", -- Mind Bomb
|
||||||
[2094] = "disorient", -- Blind
|
[2094] = "disorient", -- Blind
|
||||||
[118699] = "disorient", -- Fear
|
[118699] = "disorient", -- Fear
|
||||||
|
[130616] = "disorient", -- Fear (Horrify)
|
||||||
[5484] = "disorient", -- Howl of Terror
|
[5484] = "disorient", -- Howl of Terror
|
||||||
[261589] = "disorient", -- Seduction (Grimoire of Sacrifice)
|
[261589] = "disorient", -- Seduction (Grimoire of Sacrifice)
|
||||||
[6358] = "disorient", -- Seduction (Succubus)
|
[6358] = "disorient", -- Seduction (Succubus)
|
||||||
@ -31,9 +39,11 @@ if Lib.gameExpansion == "retail" then
|
|||||||
[221527] = "incapacitate", -- Imprison (Honor talent)
|
[221527] = "incapacitate", -- Imprison (Honor talent)
|
||||||
[2637] = "incapacitate", -- Hibernate
|
[2637] = "incapacitate", -- Hibernate
|
||||||
[99] = "incapacitate", -- Incapacitating Roar
|
[99] = "incapacitate", -- Incapacitating Roar
|
||||||
|
[378441] = "incapacitate", -- Time Stop
|
||||||
[3355] = "incapacitate", -- Freezing Trap
|
[3355] = "incapacitate", -- Freezing Trap
|
||||||
[203337] = "incapacitate", -- Freezing Trap (Honor talent)
|
[203337] = "incapacitate", -- Freezing Trap (Honor talent)
|
||||||
[213691] = "incapacitate", -- Scatter Shot
|
[213691] = "incapacitate", -- Scatter Shot
|
||||||
|
[383121] = "incapacitate", -- Mass Polymorph
|
||||||
[118] = "incapacitate", -- Polymorph
|
[118] = "incapacitate", -- Polymorph
|
||||||
[28271] = "incapacitate", -- Polymorph (Turtle)
|
[28271] = "incapacitate", -- Polymorph (Turtle)
|
||||||
[28272] = "incapacitate", -- Polymorph (Pig)
|
[28272] = "incapacitate", -- Polymorph (Pig)
|
||||||
@ -48,8 +58,11 @@ if Lib.gameExpansion == "retail" then
|
|||||||
[161372] = "incapacitate", -- Polymorph (Peacock)
|
[161372] = "incapacitate", -- Polymorph (Peacock)
|
||||||
[277787] = "incapacitate", -- Polymorph (Baby Direhorn)
|
[277787] = "incapacitate", -- Polymorph (Baby Direhorn)
|
||||||
[277792] = "incapacitate", -- Polymorph (Bumblebee)
|
[277792] = "incapacitate", -- Polymorph (Bumblebee)
|
||||||
|
[321395] = "incapacitate", -- Polymorph (Mawrat)
|
||||||
|
[391622] = "incapacitate", -- Polymorph (Duck)
|
||||||
[82691] = "incapacitate", -- Ring of Frost
|
[82691] = "incapacitate", -- Ring of Frost
|
||||||
[115078] = "incapacitate", -- Paralysis
|
[115078] = "incapacitate", -- Paralysis
|
||||||
|
[357768] = "incapacitate", -- Paralysis 2 (Perpetual Paralysis?)
|
||||||
[20066] = "incapacitate", -- Repentance
|
[20066] = "incapacitate", -- Repentance
|
||||||
[9484] = "incapacitate", -- Shackle Undead
|
[9484] = "incapacitate", -- Shackle Undead
|
||||||
[200196] = "incapacitate", -- Holy Word: Chastise
|
[200196] = "incapacitate", -- Holy Word: Chastise
|
||||||
@ -72,9 +85,12 @@ if Lib.gameExpansion == "retail" then
|
|||||||
|
|
||||||
[47476] = "silence", -- Strangulate
|
[47476] = "silence", -- Strangulate
|
||||||
[204490] = "silence", -- Sigil of Silence
|
[204490] = "silence", -- Sigil of Silence
|
||||||
-- [78675] = "silence", -- Solar Beam (doesn't seem to DR)
|
-- [78675] = "silence", -- Solar Beam (has no DR)
|
||||||
|
[410065] = "silence", -- Reactive Resin
|
||||||
[202933] = "silence", -- Spider Sting
|
[202933] = "silence", -- Spider Sting
|
||||||
[356727] = "silence", -- Spider Venom
|
[356727] = "silence", -- Spider Venom
|
||||||
|
[354831] = "silence", -- Wailing Arrow 1
|
||||||
|
[355596] = "silence", -- Wailing Arrow 2
|
||||||
[217824] = "silence", -- Shield of Virtue
|
[217824] = "silence", -- Shield of Virtue
|
||||||
[15487] = "silence", -- Silence
|
[15487] = "silence", -- Silence
|
||||||
[1330] = "silence", -- Garrote
|
[1330] = "silence", -- Garrote
|
||||||
@ -97,10 +113,14 @@ if Lib.gameExpansion == "retail" then
|
|||||||
[5211] = "stun", -- Mighty Bash
|
[5211] = "stun", -- Mighty Bash
|
||||||
[202244] = "stun", -- Overrun
|
[202244] = "stun", -- Overrun
|
||||||
[325321] = "stun", -- Wild Hunt's Charge
|
[325321] = "stun", -- Wild Hunt's Charge
|
||||||
|
[372245] = "stun", -- Terror of the Skies
|
||||||
|
[117526] = "stun", -- Binding Shot
|
||||||
[357021] = "stun", -- Consecutive Concussion
|
[357021] = "stun", -- Consecutive Concussion
|
||||||
[24394] = "stun", -- Intimidation
|
[24394] = "stun", -- Intimidation
|
||||||
|
[389831] = "stun", -- Snowdrift
|
||||||
[119381] = "stun", -- Leg Sweep
|
[119381] = "stun", -- Leg Sweep
|
||||||
[202346] = "stun", -- Double Barrel
|
[202346] = "stun", -- Double Barrel
|
||||||
|
[385149] = "stun", -- Exorcism
|
||||||
[853] = "stun", -- Hammer of Justice
|
[853] = "stun", -- Hammer of Justice
|
||||||
[255941] = "stun", -- Wake of Ashes
|
[255941] = "stun", -- Wake of Ashes
|
||||||
[64044] = "stun", -- Psychic Horror
|
[64044] = "stun", -- Psychic Horror
|
||||||
@ -114,6 +134,7 @@ if Lib.gameExpansion == "retail" then
|
|||||||
[171017] = "stun", -- Meteor Strike (Infernal)
|
[171017] = "stun", -- Meteor Strike (Infernal)
|
||||||
[171018] = "stun", -- Meteor Strike (Abyssal)
|
[171018] = "stun", -- Meteor Strike (Abyssal)
|
||||||
[30283] = "stun", -- Shadowfury
|
[30283] = "stun", -- Shadowfury
|
||||||
|
[385954] = "stun", -- Shield Charge
|
||||||
[46968] = "stun", -- Shockwave
|
[46968] = "stun", -- Shockwave
|
||||||
[132168] = "stun", -- Shockwave (Protection)
|
[132168] = "stun", -- Shockwave (Protection)
|
||||||
[145047] = "stun", -- Shockwave (Proving Grounds PvE)
|
[145047] = "stun", -- Shockwave (Proving Grounds PvE)
|
||||||
@ -123,13 +144,16 @@ if Lib.gameExpansion == "retail" then
|
|||||||
[255723] = "stun", -- Bull Rush (Highmountain Tauren)
|
[255723] = "stun", -- Bull Rush (Highmountain Tauren)
|
||||||
[287712] = "stun", -- Haymaker (Kul Tiran)
|
[287712] = "stun", -- Haymaker (Kul Tiran)
|
||||||
[332423] = "stun", -- Sparkling Driftglobe Core (Kyrian Covenant)
|
[332423] = "stun", -- Sparkling Driftglobe Core (Kyrian Covenant)
|
||||||
|
-- TODO: Inferal Awakening?
|
||||||
|
|
||||||
[204085] = "root", -- Deathchill (Chains of Ice)
|
[204085] = "root", -- Deathchill (Chains of Ice)
|
||||||
[233395] = "root", -- Deathchill (Remorseless Winter)
|
[233395] = "root", -- Deathchill (Remorseless Winter)
|
||||||
[339] = "root", -- Entangling Roots
|
[339] = "root", -- Entangling Roots
|
||||||
|
[235963] = "root", -- Entangling Roots (Earthen Grasp)
|
||||||
[170855] = "root", -- Entangling Roots (Nature's Grasp)
|
[170855] = "root", -- Entangling Roots (Nature's Grasp)
|
||||||
[102359] = "root", -- Mass Entanglement
|
[102359] = "root", -- Mass Entanglement
|
||||||
[117526] = "root", -- Binding Shot
|
[355689] = "root", -- Landslide
|
||||||
|
[393456] = "root", -- Entrapment (Tar Trap)
|
||||||
[162480] = "root", -- Steel Trap
|
[162480] = "root", -- Steel Trap
|
||||||
[273909] = "root", -- Steelclaw Trap
|
[273909] = "root", -- Steelclaw Trap
|
||||||
-- [190927] = "root_harpoon", -- Harpoon (TODO: confirm)
|
-- [190927] = "root_harpoon", -- Harpoon (TODO: confirm)
|
||||||
@ -137,19 +161,26 @@ if Lib.gameExpansion == "retail" then
|
|||||||
[201158] = "root", -- Super Sticky Tar
|
[201158] = "root", -- Super Sticky Tar
|
||||||
[122] = "root", -- Frost Nova
|
[122] = "root", -- Frost Nova
|
||||||
[33395] = "root", -- Freeze
|
[33395] = "root", -- Freeze
|
||||||
|
[386770] = "root", -- Freezing Cold
|
||||||
[198121] = "root", -- Frostbite
|
[198121] = "root", -- Frostbite
|
||||||
|
[114404] = "root", -- Void Tendril's Grasp
|
||||||
[342375] = "root", -- Tormenting Backlash (Torghast PvE)
|
[342375] = "root", -- Tormenting Backlash (Torghast PvE)
|
||||||
[233582] = "root", -- Entrenched in Flame
|
[233582] = "root", -- Entrenched in Flame
|
||||||
[116706] = "root", -- Disable
|
[116706] = "root", -- Disable
|
||||||
[324382] = "root", -- Clash
|
[324382] = "root", -- Clash
|
||||||
[64695] = "root", -- Earthgrab (Totem effect)
|
[64695] = "root", -- Earthgrab (Totem effect)
|
||||||
|
-- [356738] = "root", -- Earth Unleashed (doesn't seem to DR)
|
||||||
[285515] = "root", -- Surge of Power
|
[285515] = "root", -- Surge of Power
|
||||||
|
[199042] = "root", -- Thunderstruck (Protection PvP Talent)
|
||||||
|
--[356356] = "root", -- Warbringer TODO: has DR?
|
||||||
[39965] = "root", -- Frost Grenade (Item)
|
[39965] = "root", -- Frost Grenade (Item)
|
||||||
[75148] = "root", -- Embersilk Net (Item)
|
[75148] = "root", -- Embersilk Net (Item)
|
||||||
[55536] = "root", -- Frostweave Net (Item)
|
[55536] = "root", -- Frostweave Net (Item)
|
||||||
[268966] = "root", -- Hooked Deep Sea Net (Item)
|
[268966] = "root", -- Hooked Deep Sea Net (Item)
|
||||||
|
|
||||||
[209749] = "disarm", -- Faerie Swarm (Balance Honor Talent)
|
[209749] = "disarm", -- Faerie Swarm (Balance Honor Talent)
|
||||||
|
[407032] = "disarm", -- Sticky Tar Bomb 1
|
||||||
|
[407031] = "disarm", -- Sticky Tar Bomb 2
|
||||||
[207777] = "disarm", -- Dismantle
|
[207777] = "disarm", -- Dismantle
|
||||||
[233759] = "disarm", -- Grapple Weapon
|
[233759] = "disarm", -- Grapple Weapon
|
||||||
[236077] = "disarm", -- Disarm
|
[236077] = "disarm", -- Disarm
|
||||||
@ -214,6 +245,8 @@ elseif Lib.gameExpansion == "tbc" then
|
|||||||
[11285] = "incapacitate", -- Gouge (Rank 4)
|
[11285] = "incapacitate", -- Gouge (Rank 4)
|
||||||
[11286] = "incapacitate", -- Gouge (Rank 5)
|
[11286] = "incapacitate", -- Gouge (Rank 5)
|
||||||
[38764] = "incapacitate", -- Gouge (Rank 6)
|
[38764] = "incapacitate", -- Gouge (Rank 6)
|
||||||
|
[710] = "incapacitate", -- Banish (Rank 1)
|
||||||
|
[18647] = "incapacitate", -- Banish (Rank 2)
|
||||||
[13327] = "incapacitate", -- Reckless Charge (Rocket Helmet)
|
[13327] = "incapacitate", -- Reckless Charge (Rocket Helmet)
|
||||||
[4064] = "incapacitate", -- Rough Copper Bomb
|
[4064] = "incapacitate", -- Rough Copper Bomb
|
||||||
[4065] = "incapacitate", -- Large Copper Bomb
|
[4065] = "incapacitate", -- Large Copper Bomb
|
||||||
@ -353,7 +386,7 @@ elseif Lib.gameExpansion == "tbc" then
|
|||||||
[27067] = "counterattack", -- Counterattack (Rank 4)
|
[27067] = "counterattack", -- Counterattack (Rank 4)
|
||||||
}
|
}
|
||||||
|
|
||||||
elseif Lib.gameExpansion == "wotlk" then -- STILL WORK IN PROGRESS, I DON'T HAVE BETA ACCESS
|
elseif Lib.gameExpansion == "wotlk" then
|
||||||
|
|
||||||
-- SpellID list for Wrath of the Lich King.
|
-- SpellID list for Wrath of the Lich King.
|
||||||
-- spellID for every rank is used over spell name to avoid name collisions, and faster lookups
|
-- spellID for every rank is used over spell name to avoid name collisions, and faster lookups
|
||||||
@ -408,6 +441,9 @@ elseif Lib.gameExpansion == "wotlk" then -- STILL WORK IN PROGRESS, I DON'T HAVE
|
|||||||
[30216] = "incapacitate", -- Fel Iron Bomb
|
[30216] = "incapacitate", -- Fel Iron Bomb
|
||||||
[30461] = "incapacitate", -- The Bigger One
|
[30461] = "incapacitate", -- The Bigger One
|
||||||
[30217] = "incapacitate", -- Adamantite Grenade
|
[30217] = "incapacitate", -- Adamantite Grenade
|
||||||
|
[67769] = "incapacitate", -- Cobalt Frag Bomb
|
||||||
|
[67890] = "incapacitate", -- Cobalt Frag Bomb (Frag Belt)
|
||||||
|
[54466] = "incapacitate", -- Saronite Grenade
|
||||||
|
|
||||||
[47481] = "stun", -- Gnaw (Ghoul Pet)
|
[47481] = "stun", -- Gnaw (Ghoul Pet)
|
||||||
[5211] = "stun", -- Bash (Rank 1)
|
[5211] = "stun", -- Bash (Rank 1)
|
||||||
@ -497,6 +533,7 @@ elseif Lib.gameExpansion == "wotlk" then -- STILL WORK IN PROGRESS, I DON'T HAVE
|
|||||||
[9853] = "root", -- Entangling Roots (Rank 6)
|
[9853] = "root", -- Entangling Roots (Rank 6)
|
||||||
[26989] = "root", -- Entangling Roots (Rank 7)
|
[26989] = "root", -- Entangling Roots (Rank 7)
|
||||||
[53308] = "root", -- Entangling Roots (Rank 8)
|
[53308] = "root", -- Entangling Roots (Rank 8)
|
||||||
|
[65857] = "root", -- Entangling Roots (Rank 8) (TODO: Not sure which ID is correct)
|
||||||
[19975] = "root", -- Nature's Grasp (Rank 1)
|
[19975] = "root", -- Nature's Grasp (Rank 1)
|
||||||
[19974] = "root", -- Nature's Grasp (Rank 2)
|
[19974] = "root", -- Nature's Grasp (Rank 2)
|
||||||
[19973] = "root", -- Nature's Grasp (Rank 3)
|
[19973] = "root", -- Nature's Grasp (Rank 3)
|
||||||
@ -504,7 +541,8 @@ elseif Lib.gameExpansion == "wotlk" then -- STILL WORK IN PROGRESS, I DON'T HAVE
|
|||||||
[19971] = "root", -- Nature's Grasp (Rank 5)
|
[19971] = "root", -- Nature's Grasp (Rank 5)
|
||||||
[19970] = "root", -- Nature's Grasp (Rank 6)
|
[19970] = "root", -- Nature's Grasp (Rank 6)
|
||||||
[27010] = "root", -- Nature's Grasp (Rank 7)
|
[27010] = "root", -- Nature's Grasp (Rank 7)
|
||||||
[53312] = "root", -- Nature's Grasp (Rank 8)
|
[53313] = "root", -- Nature's Grasp (Rank 8)
|
||||||
|
[66070] = "root", -- Nature's Grasp (Rank 8) (TODO: Not sure which ID is correct)
|
||||||
[50245] = "root", -- Pin (Rank 1)
|
[50245] = "root", -- Pin (Rank 1)
|
||||||
[53544] = "root", -- Pin (Rank 2)
|
[53544] = "root", -- Pin (Rank 2)
|
||||||
[53545] = "root", -- Pin (Rank 3)
|
[53545] = "root", -- Pin (Rank 3)
|
||||||
@ -518,8 +556,10 @@ elseif Lib.gameExpansion == "wotlk" then -- STILL WORK IN PROGRESS, I DON'T HAVE
|
|||||||
[10230] = "root", -- Frost Nova (Rank 4)
|
[10230] = "root", -- Frost Nova (Rank 4)
|
||||||
[27088] = "root", -- Frost Nova (Rank 5)
|
[27088] = "root", -- Frost Nova (Rank 5)
|
||||||
[42917] = "root", -- Frost Nova (Rank 6)
|
[42917] = "root", -- Frost Nova (Rank 6)
|
||||||
|
[64695] = "root", -- Earthgrab
|
||||||
[39965] = "root", -- Frost Grenade (Item)
|
[39965] = "root", -- Frost Grenade (Item)
|
||||||
[63685] = "root", -- Freeze (Frost Shock)
|
[63685] = "root", -- Freeze (Frost Shock)
|
||||||
|
[55536] = "root", -- Frostweave Net (Item)
|
||||||
|
|
||||||
[12494] = "random_root", -- Frostbite
|
[12494] = "random_root", -- Frostbite
|
||||||
[55080] = "random_root", -- Shattered Barrier
|
[55080] = "random_root", -- Shattered Barrier
|
||||||
@ -535,6 +575,7 @@ elseif Lib.gameExpansion == "wotlk" then -- STILL WORK IN PROGRESS, I DON'T HAVE
|
|||||||
[53540] = "disarm", -- Snatch (Rank 4)
|
[53540] = "disarm", -- Snatch (Rank 4)
|
||||||
[53542] = "disarm", -- Snatch (Rank 5)
|
[53542] = "disarm", -- Snatch (Rank 5)
|
||||||
[53543] = "disarm", -- Snatch (Rank 6)
|
[53543] = "disarm", -- Snatch (Rank 6)
|
||||||
|
[64346] = "disarm", -- Fiery Payback
|
||||||
[64058] = "disarm", -- Psychic Horror Disarm Effect
|
[64058] = "disarm", -- Psychic Horror Disarm Effect
|
||||||
[51722] = "disarm", -- Dismantle
|
[51722] = "disarm", -- Dismantle
|
||||||
[676] = "disarm", -- Disarm
|
[676] = "disarm", -- Disarm
|
||||||
@ -552,8 +593,8 @@ elseif Lib.gameExpansion == "wotlk" then -- STILL WORK IN PROGRESS, I DON'T HAVE
|
|||||||
[24259] = "silence", -- Spell Lock
|
[24259] = "silence", -- Spell Lock
|
||||||
[43523] = "silence", -- Unstable Affliction 1
|
[43523] = "silence", -- Unstable Affliction 1
|
||||||
[31117] = "silence", -- Unstable Affliction 2
|
[31117] = "silence", -- Unstable Affliction 2
|
||||||
[18498] = "silence", -- Silenced - Gag Order 1
|
[18498] = "silence", -- Silenced - Gag Order (Shield Slam)
|
||||||
[74347] = "silence", -- Silenced - Gag Order 1
|
[74347] = "silence", -- Silenced - Gag Order (Heroic Throw?)
|
||||||
[50613] = "silence", -- Arcane Torrent (Racial, Runic Power)
|
[50613] = "silence", -- Arcane Torrent (Racial, Runic Power)
|
||||||
[28730] = "silence", -- Arcane Torrent (Racial, Mana)
|
[28730] = "silence", -- Arcane Torrent (Racial, Mana)
|
||||||
[25046] = "silence", -- Arcane Torrent (Racial, Energy)
|
[25046] = "silence", -- Arcane Torrent (Racial, Energy)
|
||||||
@ -585,6 +626,7 @@ elseif Lib.gameExpansion == "wotlk" then -- STILL WORK IN PROGRESS, I DON'T HAVE
|
|||||||
[33786] = "cyclone", -- Cyclone
|
[33786] = "cyclone", -- Cyclone
|
||||||
[605] = "mind_control", -- Mind Control
|
[605] = "mind_control", -- Mind Control
|
||||||
[13181] = "mind_control", -- Gnomish Mind Control Cap
|
[13181] = "mind_control", -- Gnomish Mind Control Cap
|
||||||
|
[67799] = "mind_control", -- Mind Amplification Dish
|
||||||
[7922] = "charge", -- Charge Stun
|
[7922] = "charge", -- Charge Stun
|
||||||
[19306] = "counterattack", -- Counterattack 1
|
[19306] = "counterattack", -- Counterattack 1
|
||||||
[20909] = "counterattack", -- Counterattack 2
|
[20909] = "counterattack", -- Counterattack 2
|
||||||
@ -592,9 +634,6 @@ elseif Lib.gameExpansion == "wotlk" then -- STILL WORK IN PROGRESS, I DON'T HAVE
|
|||||||
[27067] = "counterattack", -- Counterattack 4
|
[27067] = "counterattack", -- Counterattack 4
|
||||||
[48998] = "counterattack", -- Counterattack 5
|
[48998] = "counterattack", -- Counterattack 5
|
||||||
[48999] = "counterattack", -- Counterattack 6
|
[48999] = "counterattack", -- Counterattack 6
|
||||||
--Storm, Earth and Fire has no DR
|
|
||||||
|
|
||||||
-- TODO: profession stuff
|
|
||||||
}
|
}
|
||||||
|
|
||||||
elseif Lib.gameExpansion == "classic" then
|
elseif Lib.gameExpansion == "classic" then
|
||||||
|
@ -51,7 +51,7 @@ GlowMaskPool.parent = GlowParent
|
|||||||
|
|
||||||
local TexPoolResetter = function(pool,tex)
|
local TexPoolResetter = function(pool,tex)
|
||||||
local maskNum = tex:GetNumMaskTextures()
|
local maskNum = tex:GetNumMaskTextures()
|
||||||
for i = maskNum,1 do
|
for i = maskNum , 1, -1 do
|
||||||
tex:RemoveMaskTexture(tex:GetMaskTexture(i))
|
tex:RemoveMaskTexture(tex:GetMaskTexture(i))
|
||||||
end
|
end
|
||||||
tex:Hide()
|
tex:Hide()
|
||||||
@ -93,14 +93,14 @@ lib.GlowFramePool = GlowFramePool
|
|||||||
|
|
||||||
local function addFrameAndTex(r,color,name,key,N,xOffset,yOffset,texture,texCoord,desaturated,frameLevel)
|
local function addFrameAndTex(r,color,name,key,N,xOffset,yOffset,texture,texCoord,desaturated,frameLevel)
|
||||||
key = key or ""
|
key = key or ""
|
||||||
frameLevel = frameLevel or 8
|
frameLevel = frameLevel or 8
|
||||||
if not r[name..key] then
|
if not r[name..key] then
|
||||||
r[name..key] = GlowFramePool:Acquire()
|
r[name..key] = GlowFramePool:Acquire()
|
||||||
r[name..key]:SetParent(r)
|
r[name..key]:SetParent(r)
|
||||||
r[name..key].name = name..key
|
r[name..key].name = name..key
|
||||||
end
|
end
|
||||||
local f = r[name..key]
|
local f = r[name..key]
|
||||||
f:SetFrameLevel(r:GetFrameLevel()+frameLevel)
|
f:SetFrameLevel(r:GetFrameLevel()+frameLevel)
|
||||||
f:SetPoint("TOPLEFT",r,"TOPLEFT",-xOffset+0.05,yOffset+0.05)
|
f:SetPoint("TOPLEFT",r,"TOPLEFT",-xOffset+0.05,yOffset+0.05)
|
||||||
f:SetPoint("BOTTOMRIGHT",r,"BOTTOMRIGHT",xOffset,-yOffset+0.05)
|
f:SetPoint("BOTTOMRIGHT",r,"BOTTOMRIGHT",xOffset,-yOffset+0.05)
|
||||||
f:Show()
|
f:Show()
|
||||||
@ -613,7 +613,7 @@ function lib.ButtonGlow_Start(r,color,frequency,frameLevel)
|
|||||||
if not r then
|
if not r then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
frameLevel = frameLevel or 8;
|
frameLevel = frameLevel or 8;
|
||||||
local throttle
|
local throttle
|
||||||
if frequency and frequency > 0 then
|
if frequency and frequency > 0 then
|
||||||
throttle = 0.25/frequency*0.01
|
throttle = 0.25/frequency*0.01
|
||||||
@ -628,8 +628,8 @@ function lib.ButtonGlow_Start(r,color,frequency,frameLevel)
|
|||||||
f:SetPoint("TOPLEFT", r, "TOPLEFT", -width * 0.2, height * 0.2)
|
f:SetPoint("TOPLEFT", r, "TOPLEFT", -width * 0.2, height * 0.2)
|
||||||
f:SetPoint("BOTTOMRIGHT", r, "BOTTOMRIGHT", width * 0.2, -height * 0.2)
|
f:SetPoint("BOTTOMRIGHT", r, "BOTTOMRIGHT", width * 0.2, -height * 0.2)
|
||||||
f.ants:SetSize(width*1.4*0.85, height*1.4*0.85)
|
f.ants:SetSize(width*1.4*0.85, height*1.4*0.85)
|
||||||
AnimIn_OnFinished(f.animIn)
|
AnimIn_OnFinished(f.animIn)
|
||||||
if f.animOut:IsPlaying() then
|
if f.animOut:IsPlaying() then
|
||||||
f.animOut:Stop()
|
f.animOut:Stop()
|
||||||
f.animIn:Play()
|
f.animIn:Play()
|
||||||
end
|
end
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
|
--@curseforge-project-slug: libsharedmedia-3-0@
|
||||||
--[[
|
--[[
|
||||||
Name: LibSharedMedia-3.0
|
Name: LibSharedMedia-3.0
|
||||||
Revision: $Revision: 114 $
|
Revision: $Revision: 128 $
|
||||||
Author: Elkano (elkano@gmx.de)
|
Author: Elkano (elkano@gmx.de)
|
||||||
Inspired By: SurfaceLib by Haste/Otravi (troeks@gmail.com)
|
Inspired By: SurfaceLib by Haste/Otravi (troeks@gmail.com)
|
||||||
Website: http://www.wowace.com/projects/libsharedmedia-3-0/
|
Website: http://www.wowace.com/projects/libsharedmedia-3-0/
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<Ui xmlns="http://www.blizzard.com/wow/ui/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.blizzard.com/wow/ui/
|
<Ui xmlns="http://www.blizzard.com/wow/ui/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.blizzard.com/wow/ui/
|
||||||
..\FrameXML\UI.xsd">
|
..\FrameXML\UI.xsd">
|
||||||
<Script file="LibSharedMedia-3.0.lua" />
|
<Script file="LibSharedMedia-3.0.lua" />
|
||||||
</Ui>
|
</Ui>
|
||||||
|
@ -7,24 +7,24 @@ if not LibStub or LibStub.minor < LIBSTUB_MINOR then
|
|||||||
LibStub = LibStub or {libs = {}, minors = {} }
|
LibStub = LibStub or {libs = {}, minors = {} }
|
||||||
_G[LIBSTUB_MAJOR] = LibStub
|
_G[LIBSTUB_MAJOR] = LibStub
|
||||||
LibStub.minor = LIBSTUB_MINOR
|
LibStub.minor = LIBSTUB_MINOR
|
||||||
|
|
||||||
function LibStub:NewLibrary(major, minor)
|
function LibStub:NewLibrary(major, minor)
|
||||||
assert(type(major) == "string", "Bad argument #2 to `NewLibrary' (string expected)")
|
assert(type(major) == "string", "Bad argument #2 to `NewLibrary' (string expected)")
|
||||||
minor = assert(tonumber(strmatch(minor, "%d+")), "Minor version must either be a number or contain a number.")
|
minor = assert(tonumber(string.match(minor, "%d+")), "Minor version must either be a number or contain a number.")
|
||||||
|
|
||||||
local oldminor = self.minors[major]
|
local oldminor = self.minors[major]
|
||||||
if oldminor and oldminor >= minor then return nil end
|
if oldminor and oldminor >= minor then return nil end
|
||||||
self.minors[major], self.libs[major] = minor, self.libs[major] or {}
|
self.minors[major], self.libs[major] = minor, self.libs[major] or {}
|
||||||
return self.libs[major], oldminor
|
return self.libs[major], oldminor
|
||||||
end
|
end
|
||||||
|
|
||||||
function LibStub:GetLibrary(major, silent)
|
function LibStub:GetLibrary(major, silent)
|
||||||
if not self.libs[major] and not silent then
|
if not self.libs[major] and not silent then
|
||||||
error(("Cannot find a library instance of %q."):format(tostring(major)), 2)
|
error(("Cannot find a library instance of %q."):format(tostring(major)), 2)
|
||||||
end
|
end
|
||||||
return self.libs[major], self.minors[major]
|
return self.libs[major], self.minors[major]
|
||||||
end
|
end
|
||||||
|
|
||||||
function LibStub:IterateLibraries() return pairs(self.libs) end
|
function LibStub:IterateLibraries() return pairs(self.libs) end
|
||||||
setmetatable(LibStub, { __call = LibStub.GetLibrary })
|
setmetatable(LibStub, { __call = LibStub.GetLibrary })
|
||||||
end
|
end
|
||||||
|
@ -27,19 +27,19 @@ function ACDFrame:Initialize()
|
|||||||
self.ACDNumFrame:SetPoint("CENTER", 0, 128)
|
self.ACDNumFrame:SetPoint("CENTER", 0, 128)
|
||||||
self.ACDNumFrame:Hide()
|
self.ACDNumFrame:Hide()
|
||||||
|
|
||||||
local ACDNumTens = ACDNumFrame:CreateTexture("ACDNumTens", "HIGH")
|
local ACDNumTens = ACDNumFrame:CreateTexture("ACDNumTens", "OVERLAY")
|
||||||
self.ACDNumTens = ACDNumTens
|
self.ACDNumTens = ACDNumTens
|
||||||
self.ACDNumTens:SetWidth(Gladdy.db.arenaCountdownSize)
|
self.ACDNumTens:SetWidth(Gladdy.db.arenaCountdownSize)
|
||||||
self.ACDNumTens:SetHeight(Gladdy.db.arenaCountdownSize)
|
self.ACDNumTens:SetHeight(Gladdy.db.arenaCountdownSize)
|
||||||
self.ACDNumTens:SetPoint("CENTER", self.ACDNumFrame, "CENTER", -(Gladdy.db.arenaCountdownSize/8 + Gladdy.db.arenaCountdownSize/8/2), 0)
|
self.ACDNumTens:SetPoint("CENTER", self.ACDNumFrame, "CENTER", -(Gladdy.db.arenaCountdownSize/8 + Gladdy.db.arenaCountdownSize/8/2), 0)
|
||||||
|
|
||||||
local ACDNumOnes = ACDNumFrame:CreateTexture("ACDNumOnes", "HIGH")
|
local ACDNumOnes = ACDNumFrame:CreateTexture("ACDNumOnes", "OVERLAY")
|
||||||
self.ACDNumOnes = ACDNumOnes
|
self.ACDNumOnes = ACDNumOnes
|
||||||
self.ACDNumOnes:SetWidth(Gladdy.db.arenaCountdownSize)
|
self.ACDNumOnes:SetWidth(Gladdy.db.arenaCountdownSize)
|
||||||
self.ACDNumOnes:SetHeight(Gladdy.db.arenaCountdownSize)
|
self.ACDNumOnes:SetHeight(Gladdy.db.arenaCountdownSize)
|
||||||
self.ACDNumOnes:SetPoint("CENTER", self.ACDNumFrame, "CENTER", (Gladdy.db.arenaCountdownSize/8 + Gladdy.db.arenaCountdownSize/8/2), 0)
|
self.ACDNumOnes:SetPoint("CENTER", self.ACDNumFrame, "CENTER", (Gladdy.db.arenaCountdownSize/8 + Gladdy.db.arenaCountdownSize/8/2), 0)
|
||||||
|
|
||||||
local ACDNumOne = ACDNumFrame:CreateTexture("ACDNumOne", "HIGH")
|
local ACDNumOne = ACDNumFrame:CreateTexture("ACDNumOne", "OVERLAY")
|
||||||
self.ACDNumOne = ACDNumOne
|
self.ACDNumOne = ACDNumOne
|
||||||
self.ACDNumOne:SetWidth(Gladdy.db.arenaCountdownSize)
|
self.ACDNumOne:SetWidth(Gladdy.db.arenaCountdownSize)
|
||||||
self.ACDNumOne:SetHeight(Gladdy.db.arenaCountdownSize)
|
self.ACDNumOne:SetHeight(Gladdy.db.arenaCountdownSize)
|
||||||
|
@ -130,7 +130,7 @@ function Auras:CreateFrame(unit)
|
|||||||
self.frame:SetAlpha(1)
|
self.frame:SetAlpha(1)
|
||||||
end
|
end
|
||||||
if (self.timeLeft <= 0) then
|
if (self.timeLeft <= 0) then
|
||||||
Auras:AURA_FADE(self.unit, self.track)
|
Auras:AURA_FADE(self.unit, self.track, true)
|
||||||
else
|
else
|
||||||
if self.spellID == 8178 then
|
if self.spellID == 8178 then
|
||||||
self.text:SetText("")
|
self.text:SetText("")
|
||||||
@ -331,13 +331,13 @@ function Auras:UpdateFrame(unit)
|
|||||||
|
|
||||||
if Gladdy.db.auraIconZoomed then
|
if Gladdy.db.auraIconZoomed then
|
||||||
if auraFrame.icon.masked then
|
if auraFrame.icon.masked then
|
||||||
auraFrame.icon:SetMask(nil)
|
auraFrame.icon:SetMask("")
|
||||||
auraFrame.icon:SetTexCoord(0.1,0.9,0.1,0.9)
|
auraFrame.icon:SetTexCoord(0.1,0.9,0.1,0.9)
|
||||||
auraFrame.icon.masked = nil
|
auraFrame.icon.masked = nil
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if not auraFrame.icon.masked then
|
if not auraFrame.icon.masked then
|
||||||
auraFrame.icon:SetMask(nil)
|
auraFrame.icon:SetMask("")
|
||||||
auraFrame.icon:SetTexCoord(0,1,0,1)
|
auraFrame.icon:SetTexCoord(0,1,0,1)
|
||||||
auraFrame.icon:SetMask("Interface\\AddOns\\Gladdy\\Images\\mask")
|
auraFrame.icon:SetMask("Interface\\AddOns\\Gladdy\\Images\\mask")
|
||||||
auraFrame.icon.masked = true
|
auraFrame.icon.masked = true
|
||||||
@ -479,13 +479,13 @@ function Auras:UpdateInterruptFrame(unit)
|
|||||||
|
|
||||||
if Gladdy.db.auraInterruptIconZoomed then
|
if Gladdy.db.auraInterruptIconZoomed then
|
||||||
if interruptFrame.icon.masked then
|
if interruptFrame.icon.masked then
|
||||||
interruptFrame.icon:SetMask(nil)
|
interruptFrame.icon:SetMask("")
|
||||||
interruptFrame.icon:SetTexCoord(0.1,0.9,0.1,0.9)
|
interruptFrame.icon:SetTexCoord(0.1,0.9,0.1,0.9)
|
||||||
interruptFrame.icon.masked = nil
|
interruptFrame.icon.masked = nil
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if not interruptFrame.icon.masked then
|
if not interruptFrame.icon.masked then
|
||||||
interruptFrame.icon:SetMask(nil)
|
interruptFrame.icon:SetMask("")
|
||||||
interruptFrame.icon:SetTexCoord(0,1,0,1)
|
interruptFrame.icon:SetTexCoord(0,1,0,1)
|
||||||
interruptFrame.icon:SetMask("Interface\\AddOns\\Gladdy\\Images\\mask")
|
interruptFrame.icon:SetMask("Interface\\AddOns\\Gladdy\\Images\\mask")
|
||||||
interruptFrame.icon.masked = true
|
interruptFrame.icon.masked = true
|
||||||
@ -554,8 +554,6 @@ function Auras:Test(unit)
|
|||||||
self:AURA_GAIN(unit,v.value.track, spellid, spellName, icon, duration, GetTime() + duration)
|
self:AURA_GAIN(unit,v.value.track, spellid, spellName, icon, duration, GetTime() + duration)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
-- /run LibStub("Gladdy").modules["Auras"]:Test("arena1")
|
|
||||||
-- /run LibStub("Gladdy"):JoinedArena()
|
|
||||||
|
|
||||||
--Interrupts
|
--Interrupts
|
||||||
if (unit == "arena1" or unit == "arena3") then
|
if (unit == "arena1" or unit == "arena3") then
|
||||||
@ -596,10 +594,6 @@ function Auras:AURA_GAIN(unit, auraType, spellID, spellName, icon, duration, exp
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
if spellID == 31117 then
|
|
||||||
spellName = "Unstable Affliction Silence"
|
|
||||||
end
|
|
||||||
|
|
||||||
if not self.auras[spellName] then
|
if not self.auras[spellName] then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
@ -639,9 +633,9 @@ function Auras:AURA_GAIN(unit, auraType, spellID, spellName, icon, duration, exp
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function Auras:AURA_FADE(unit, auraType)
|
function Auras:AURA_FADE(unit, auraType, force)
|
||||||
local auraFrame = self.frames[unit]
|
local auraFrame = self.frames[unit]
|
||||||
if (not auraFrame or auraFrame.track ~= auraType) then
|
if (not auraFrame or auraFrame.track ~= auraType or not Gladdy.buttons[unit] or (not force and Gladdy.buttons[unit].stealthed)) then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
if auraFrame.active then
|
if auraFrame.active then
|
||||||
@ -1242,14 +1236,7 @@ function Auras:GetAuraOptions(auraType)
|
|||||||
for i,k in ipairs(auras) do
|
for i,k in ipairs(auras) do
|
||||||
options[tostring(k)] = {
|
options[tostring(k)] = {
|
||||||
type = "group",
|
type = "group",
|
||||||
name = (Gladdy:GetImportantAuras()["Unstable Affliction Silence"]
|
name = Gladdy:GetExceptionSpellName(k),
|
||||||
and Gladdy:GetImportantAuras()["Unstable Affliction Silence"].spellID == k
|
|
||||||
and Gladdy:GetImportantAuras()["Unstable Affliction Silence"].altName)
|
|
||||||
or (Gladdy:GetImportantAuras()[select(1, GetSpellInfo(27010)) .. " " .. select(1, GetSpellInfo(16689))]
|
|
||||||
and Gladdy:GetImportantAuras()[select(1, GetSpellInfo(27010)) .. " " .. select(1, GetSpellInfo(16689))].spellID == k
|
|
||||||
and Gladdy:GetImportantAuras()[select(1, GetSpellInfo(27010)) .. " " .. select(1, GetSpellInfo(16689))].altName)
|
|
||||||
or Gladdy:GetImportantAuras()[GetSpellInfo(k)].altName
|
|
||||||
or GetSpellInfo(k),
|
|
||||||
order = i+2,
|
order = i+2,
|
||||||
icon = Gladdy:GetImportantAuras()[GetSpellInfo(k)] and Gladdy:GetImportantAuras()[GetSpellInfo(k)].texture or select(3, GetSpellInfo(k)),
|
icon = Gladdy:GetImportantAuras()[GetSpellInfo(k)] and Gladdy:GetImportantAuras()[GetSpellInfo(k)].texture or select(3, GetSpellInfo(k)),
|
||||||
args = {
|
args = {
|
||||||
@ -1322,10 +1309,7 @@ function Auras:GetInterruptOptions()
|
|||||||
for i,k in ipairs(auras) do
|
for i,k in ipairs(auras) do
|
||||||
options[tostring(k)] = {
|
options[tostring(k)] = {
|
||||||
type = "group",
|
type = "group",
|
||||||
name = Gladdy:GetInterrupts()["Unstable Affliction Silence"]
|
name = GetSpellInfo(k),
|
||||||
and Gladdy:GetInterrupts()["Unstable Affliction Silence"].spellID == k
|
|
||||||
and Gladdy:GetInterrupts()["Unstable Affliction Silence"].altName
|
|
||||||
or GetSpellInfo(k),
|
|
||||||
order = i+2,
|
order = i+2,
|
||||||
icon = Gladdy:GetInterrupts()[GetSpellInfo(k)] and Gladdy:GetInterrupts()[GetSpellInfo(k)].texture or select(3, GetSpellInfo(k)),
|
icon = Gladdy:GetInterrupts()[GetSpellInfo(k)] and Gladdy:GetInterrupts()[GetSpellInfo(k)].texture or select(3, GetSpellInfo(k)),
|
||||||
args = {
|
args = {
|
||||||
|
@ -300,13 +300,13 @@ local function styleIcon(aura, auraType)
|
|||||||
|
|
||||||
if zoomedOption then
|
if zoomedOption then
|
||||||
if aura.texture.masked then
|
if aura.texture.masked then
|
||||||
aura.texture:SetMask(nil)
|
aura.texture:SetMask("")
|
||||||
aura.texture:SetTexCoord(0.1,0.9,0.1,0.9)
|
aura.texture:SetTexCoord(0.1,0.9,0.1,0.9)
|
||||||
aura.texture.masked = nil
|
aura.texture.masked = nil
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if not aura.texture.masked then
|
if not aura.texture.masked then
|
||||||
aura.texture:SetMask(nil)
|
aura.texture:SetMask("")
|
||||||
aura.texture:SetTexCoord(0,1,0,1)
|
aura.texture:SetTexCoord(0,1,0,1)
|
||||||
aura.texture:SetMask("Interface\\AddOns\\Gladdy\\Images\\mask")
|
aura.texture:SetMask("Interface\\AddOns\\Gladdy\\Images\\mask")
|
||||||
aura.texture.masked = true
|
aura.texture.masked = true
|
||||||
|
@ -123,7 +123,7 @@ function Castbar:CreateFrame(unit)
|
|||||||
castBar.icon:SetPoint("LEFT", castBar, "RIGHT", 3, 0) -- Icon of castbar
|
castBar.icon:SetPoint("LEFT", castBar, "RIGHT", 3, 0) -- Icon of castbar
|
||||||
end
|
end
|
||||||
|
|
||||||
castBar.spellText = castBar:CreateFontString(nil, "LOW")
|
castBar.spellText = castBar:CreateFontString(nil, "OVERLAY")
|
||||||
castBar.spellText:SetFont(Gladdy:SMFetch("font", "auraFont"), Gladdy.db.castBarFontSize, Gladdy.db.castBarFontOutline and "OUTLINE")
|
castBar.spellText:SetFont(Gladdy:SMFetch("font", "auraFont"), Gladdy.db.castBarFontSize, Gladdy.db.castBarFontOutline and "OUTLINE")
|
||||||
castBar.spellText:SetTextColor(Gladdy:SetColor(Gladdy.db.castBarFontColor))
|
castBar.spellText:SetTextColor(Gladdy:SetColor(Gladdy.db.castBarFontColor))
|
||||||
castBar.spellText:SetShadowOffset(1, -1)
|
castBar.spellText:SetShadowOffset(1, -1)
|
||||||
@ -131,7 +131,7 @@ function Castbar:CreateFrame(unit)
|
|||||||
castBar.spellText:SetJustifyH("CENTER")
|
castBar.spellText:SetJustifyH("CENTER")
|
||||||
castBar.spellText:SetPoint("LEFT", 10, 0) -- Text of the spell
|
castBar.spellText:SetPoint("LEFT", 10, 0) -- Text of the spell
|
||||||
|
|
||||||
castBar.timeText = castBar:CreateFontString(nil, "LOW")
|
castBar.timeText = castBar:CreateFontString(nil, "OVERLAY")
|
||||||
castBar.timeText:SetFont(Gladdy:SMFetch("font", "auraFont"), Gladdy.db.castBarFontSize, Gladdy.db.castBarFontOutline and "OUTLINE")
|
castBar.timeText:SetFont(Gladdy:SMFetch("font", "auraFont"), Gladdy.db.castBarFontSize, Gladdy.db.castBarFontOutline and "OUTLINE")
|
||||||
castBar.timeText:SetTextColor(Gladdy:SetColor(Gladdy.db.castBarFontColor))
|
castBar.timeText:SetTextColor(Gladdy:SetColor(Gladdy.db.castBarFontColor))
|
||||||
castBar.timeText:SetShadowOffset(1, -1)
|
castBar.timeText:SetShadowOffset(1, -1)
|
||||||
@ -197,13 +197,13 @@ function Castbar:UpdateFrame(unit)
|
|||||||
castBar.icon.texture:SetAllPoints(castBar.icon)
|
castBar.icon.texture:SetAllPoints(castBar.icon)
|
||||||
if Gladdy.db.castBarIconZoomed then
|
if Gladdy.db.castBarIconZoomed then
|
||||||
if castBar.icon.texture.masked then
|
if castBar.icon.texture.masked then
|
||||||
castBar.icon.texture:SetMask(nil)
|
castBar.icon.texture:SetMask("")
|
||||||
castBar.icon.texture:SetTexCoord(0.1,0.9,0.1,0.9)
|
castBar.icon.texture:SetTexCoord(0.1,0.9,0.1,0.9)
|
||||||
castBar.icon.texture.masked = nil
|
castBar.icon.texture.masked = nil
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if not castBar.icon.texture.masked then
|
if not castBar.icon.texture.masked then
|
||||||
castBar.icon.texture:SetMask(nil)
|
castBar.icon.texture:SetMask("")
|
||||||
castBar.icon.texture:SetTexCoord(0,1,0,1)
|
castBar.icon.texture:SetTexCoord(0,1,0,1)
|
||||||
castBar.icon.texture:SetMask("Interface\\AddOns\\Gladdy\\Images\\mask")
|
castBar.icon.texture:SetMask("Interface\\AddOns\\Gladdy\\Images\\mask")
|
||||||
castBar.icon.texture.masked = true
|
castBar.icon.texture.masked = true
|
||||||
|
@ -145,13 +145,13 @@ function Classicon:UpdateFrame(unit)
|
|||||||
|
|
||||||
if Gladdy.db.classIconZoomed then
|
if Gladdy.db.classIconZoomed then
|
||||||
if classIcon.texture.masked then
|
if classIcon.texture.masked then
|
||||||
classIcon.texture:SetMask(nil)
|
classIcon.texture:SetMask("")
|
||||||
classIcon.texture:SetTexCoord(0.1,0.9,0.1,0.9)
|
classIcon.texture:SetTexCoord(0.1,0.9,0.1,0.9)
|
||||||
classIcon.texture.masked = nil
|
classIcon.texture.masked = nil
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if not classIcon.texture.masked then
|
if not classIcon.texture.masked then
|
||||||
classIcon.texture:SetMask(nil)
|
classIcon.texture:SetMask("")
|
||||||
classIcon.texture:SetTexCoord(0,1,0,1)
|
classIcon.texture:SetTexCoord(0,1,0,1)
|
||||||
classIcon.texture:SetMask("Interface\\AddOns\\Gladdy\\Images\\mask")
|
classIcon.texture:SetMask("Interface\\AddOns\\Gladdy\\Images\\mask")
|
||||||
classIcon.texture.masked = true
|
classIcon.texture.masked = true
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
local type, pairs, ipairs, ceil, tonumber, mod, tostring, upper, select, tinsert, tremove = type, pairs, ipairs, ceil, tonumber, mod, tostring, string.upper, select, tinsert, tremove
|
local type, pairs, ipairs, ceil, tonumber, mod, tostring, upper, select, tinsert, tremove = type, pairs, ipairs, ceil, tonumber, mod, tostring, string.upper, select, tinsert, tremove
|
||||||
local tbl_sort = table.sort
|
local tbl_sort = table.sort
|
||||||
|
local C_Timer = C_Timer
|
||||||
local GetTime = GetTime
|
local GetTime = GetTime
|
||||||
local CreateFrame = CreateFrame
|
local CreateFrame = CreateFrame
|
||||||
local GetSpellInfo = GetSpellInfo
|
local GetSpellInfo = GetSpellInfo
|
||||||
@ -59,6 +60,7 @@ local Cooldowns = Gladdy:NewModule("Cooldowns", nil, {
|
|||||||
cooldownXOffset = 0,
|
cooldownXOffset = 0,
|
||||||
cooldownSize = 30,
|
cooldownSize = 30,
|
||||||
cooldownIconGlow = true,
|
cooldownIconGlow = true,
|
||||||
|
cooldownIconGlowColor = {r = 0.95, g = 0.95, b = 0.32, a = 1},
|
||||||
cooldownIconZoomed = false,
|
cooldownIconZoomed = false,
|
||||||
cooldownIconDesaturateOnCooldown = false,
|
cooldownIconDesaturateOnCooldown = false,
|
||||||
cooldownIconAlphaOnCooldown = 1,
|
cooldownIconAlphaOnCooldown = 1,
|
||||||
@ -85,8 +87,13 @@ function Cooldowns:Initialize()
|
|||||||
for _,spellTable in pairs(Gladdy:GetCooldownList()) do
|
for _,spellTable in pairs(Gladdy:GetCooldownList()) do
|
||||||
for spellId,val in pairs(spellTable) do
|
for spellId,val in pairs(spellTable) do
|
||||||
local spellName, _, texture = GetSpellInfo(spellId)
|
local spellName, _, texture = GetSpellInfo(spellId)
|
||||||
if type(val) == "table" and val.icon then
|
if type(val) == "table" then
|
||||||
texture = val.icon
|
if val.icon then
|
||||||
|
texture = val.icon
|
||||||
|
end
|
||||||
|
if val.altName then
|
||||||
|
spellName = val.altName
|
||||||
|
end
|
||||||
end
|
end
|
||||||
if spellName then
|
if spellName then
|
||||||
self.cooldownSpellIds[spellName] = spellId
|
self.cooldownSpellIds[spellName] = spellId
|
||||||
@ -109,7 +116,6 @@ end
|
|||||||
|
|
||||||
function Cooldowns:CreateFrame(unit)
|
function Cooldowns:CreateFrame(unit)
|
||||||
local button = Gladdy.buttons[unit]
|
local button = Gladdy.buttons[unit]
|
||||||
-- Cooldown frame
|
|
||||||
local spellCooldownFrame = CreateFrame("Frame", nil, button)
|
local spellCooldownFrame = CreateFrame("Frame", nil, button)
|
||||||
spellCooldownFrame:EnableMouse(false)
|
spellCooldownFrame:EnableMouse(false)
|
||||||
spellCooldownFrame:SetMovable(true)
|
spellCooldownFrame:SetMovable(true)
|
||||||
@ -120,7 +126,7 @@ function Cooldowns:CreateFrame(unit)
|
|||||||
self.frames[unit] = spellCooldownFrame
|
self.frames[unit] = spellCooldownFrame
|
||||||
end
|
end
|
||||||
|
|
||||||
function Cooldowns:CreateIcon() -- returns iconFrame
|
function Cooldowns:CreateIcon()
|
||||||
local icon
|
local icon
|
||||||
if (#self.iconCache > 0) then
|
if (#self.iconCache > 0) then
|
||||||
icon = tremove(self.iconCache, #self.iconCache)
|
icon = tremove(self.iconCache, #self.iconCache)
|
||||||
@ -148,6 +154,9 @@ function Cooldowns:CreateIcon() -- returns iconFrame
|
|||||||
icon.cooldownFont = icon.cooldownFrame:CreateFontString(nil, "OVERLAY")
|
icon.cooldownFont = icon.cooldownFrame:CreateFontString(nil, "OVERLAY")
|
||||||
icon.cooldownFont:SetAllPoints(icon)
|
icon.cooldownFont:SetAllPoints(icon)
|
||||||
|
|
||||||
|
icon.glow = CreateFrame("Frame", nil, icon)
|
||||||
|
icon.glow:SetAllPoints(icon)
|
||||||
|
|
||||||
self:UpdateIcon(icon)
|
self:UpdateIcon(icon)
|
||||||
end
|
end
|
||||||
return icon
|
return icon
|
||||||
@ -160,6 +169,8 @@ function Cooldowns:UpdateIcon(icon)
|
|||||||
icon.cooldown:SetFrameLevel(Gladdy.db.cooldownFrameLevel + 1)
|
icon.cooldown:SetFrameLevel(Gladdy.db.cooldownFrameLevel + 1)
|
||||||
icon.cooldownFrame:SetFrameStrata(Gladdy.db.cooldownFrameStrata)
|
icon.cooldownFrame:SetFrameStrata(Gladdy.db.cooldownFrameStrata)
|
||||||
icon.cooldownFrame:SetFrameLevel(Gladdy.db.cooldownFrameLevel + 2)
|
icon.cooldownFrame:SetFrameLevel(Gladdy.db.cooldownFrameLevel + 2)
|
||||||
|
icon.glow:SetFrameStrata(Gladdy.db.cooldownFrameStrata)
|
||||||
|
icon.glow:SetFrameLevel(Gladdy.db.cooldownFrameLevel + 3)
|
||||||
|
|
||||||
icon:SetHeight(Gladdy.db.cooldownSize)
|
icon:SetHeight(Gladdy.db.cooldownSize)
|
||||||
icon:SetWidth(Gladdy.db.cooldownSize * Gladdy.db.cooldownWidthFactor)
|
icon:SetWidth(Gladdy.db.cooldownSize * Gladdy.db.cooldownWidthFactor)
|
||||||
@ -185,13 +196,13 @@ function Cooldowns:UpdateIcon(icon)
|
|||||||
|
|
||||||
if Gladdy.db.cooldownIconZoomed then
|
if Gladdy.db.cooldownIconZoomed then
|
||||||
if icon.texture.masked then
|
if icon.texture.masked then
|
||||||
icon.texture:SetMask(nil)
|
icon.texture:SetMask("")
|
||||||
icon.texture:SetTexCoord(0.1,0.9,0.1,0.9)
|
icon.texture:SetTexCoord(0.1,0.9,0.1,0.9)
|
||||||
icon.texture.masked = nil
|
icon.texture.masked = nil
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if not icon.texture.masked then
|
if not icon.texture.masked then
|
||||||
icon.texture:SetMask(nil)
|
icon.texture:SetMask("")
|
||||||
icon.texture:SetTexCoord(0,1,0,1)
|
icon.texture:SetTexCoord(0,1,0,1)
|
||||||
icon.texture:SetMask("Interface\\AddOns\\Gladdy\\Images\\mask")
|
icon.texture:SetMask("Interface\\AddOns\\Gladdy\\Images\\mask")
|
||||||
icon.texture.masked = true
|
icon.texture.masked = true
|
||||||
@ -207,6 +218,9 @@ function Cooldowns:UpdateIcon(icon)
|
|||||||
else
|
else
|
||||||
icon.texture:SetAlpha(1)
|
icon.texture:SetAlpha(1)
|
||||||
end
|
end
|
||||||
|
if icon.timer and not icon.timer:IsCancelled() then
|
||||||
|
LCG.PixelGlow_Start(icon.glow, Gladdy:ColorAsArray(Gladdy.db.cooldownIconGlowColor), 12, 0.15, nil, 2)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function Cooldowns:IconsSetPoint(button)
|
function Cooldowns:IconsSetPoint(button)
|
||||||
@ -258,7 +272,6 @@ end
|
|||||||
|
|
||||||
function Cooldowns:UpdateFrame(unit)
|
function Cooldowns:UpdateFrame(unit)
|
||||||
local button = Gladdy.buttons[unit]
|
local button = Gladdy.buttons[unit]
|
||||||
-- Cooldown frame
|
|
||||||
local testAgain = false
|
local testAgain = false
|
||||||
if (Gladdy.db.cooldown) then
|
if (Gladdy.db.cooldown) then
|
||||||
button.spellCooldownFrame:SetHeight(Gladdy.db.cooldownSize)
|
button.spellCooldownFrame:SetHeight(Gladdy.db.cooldownSize)
|
||||||
@ -333,6 +346,11 @@ function Cooldowns:ClearIcon(button, index, spellId, icon)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
icon:Show()
|
||||||
|
LCG.PixelGlow_Stop(icon.glow)
|
||||||
|
if icon.timer then
|
||||||
|
icon.timer:Cancel()
|
||||||
|
end
|
||||||
icon:ClearAllPoints()
|
icon:ClearAllPoints()
|
||||||
icon:SetParent(nil)
|
icon:SetParent(nil)
|
||||||
icon:Hide()
|
icon:Hide()
|
||||||
@ -341,7 +359,6 @@ function Cooldowns:ClearIcon(button, index, spellId, icon)
|
|||||||
icon.cooldown:Hide()
|
icon.cooldown:Hide()
|
||||||
icon.cooldownFont:SetText("")
|
icon.cooldownFont:SetText("")
|
||||||
icon:SetScript("OnUpdate", nil)
|
icon:SetScript("OnUpdate", nil)
|
||||||
LCG:ButtonGlow_Stop(icon)
|
|
||||||
tinsert(self.iconCache, icon)
|
tinsert(self.iconCache, icon)
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -349,11 +366,13 @@ end
|
|||||||
-- Test
|
-- Test
|
||||||
---------------------
|
---------------------
|
||||||
|
|
||||||
|
-- /run LibStub("Gladdy").modules["Cooldowns"]:AURA_GAIN(_, AURA_TYPE_BUFF, 22812, "Barkskin", _, 20, _, _, _, _, "arena1", true)
|
||||||
|
-- /run LibStub("Gladdy").modules["Cooldowns"]:AURA_FADE("arena1", 22812)
|
||||||
function Cooldowns:Test(unit)
|
function Cooldowns:Test(unit)
|
||||||
if Gladdy.frame.testing then
|
if Gladdy.frame.testing then
|
||||||
self:UpdateTestCooldowns(unit)
|
self:UpdateTestCooldowns(unit)
|
||||||
end
|
end
|
||||||
Cooldowns:AURA_GAIN(_, AURA_TYPE_BUFF, "22812", "Barkskin", _, 20, _, _, _, _, unit, true) -- unit, auraType, spellID, spellName, texture, duration, expirationTime
|
Cooldowns:AURA_GAIN(_, AURA_TYPE_BUFF, 22812, "Barkskin", _, 20, _, _, _, _, unit, true)
|
||||||
end
|
end
|
||||||
|
|
||||||
function Cooldowns:UpdateTestCooldowns(unit)
|
function Cooldowns:UpdateTestCooldowns(unit)
|
||||||
@ -368,6 +387,9 @@ function Cooldowns:UpdateTestCooldowns(unit)
|
|||||||
end)
|
end)
|
||||||
|
|
||||||
for _,icon in ipairs(orderedIcons) do
|
for _,icon in ipairs(orderedIcons) do
|
||||||
|
if icon.timer then
|
||||||
|
icon.timer:Cancel()
|
||||||
|
end
|
||||||
self:CooldownUsed(unit, button.class, icon.spellId)
|
self:CooldownUsed(unit, button.class, icon.spellId)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -394,13 +416,9 @@ function Cooldowns:UNIT_DESTROYED(unit)
|
|||||||
self:ResetUnit(unit)
|
self:ResetUnit(unit)
|
||||||
end
|
end
|
||||||
|
|
||||||
--[[
|
|
||||||
/run local a=LibStub("Gladdy").modules["Cooldowns"] a:AURA_GAIN("arena1",22812)
|
|
||||||
/run local a=LibStub("Gladdy").modules["Cooldowns"] a:AURA_FADE("arena1",22812)
|
|
||||||
--]]
|
|
||||||
function Cooldowns:AURA_GAIN(_, auraType, spellID, spellName, _, duration, _, _, _, _, unitCaster, test)
|
function Cooldowns:AURA_GAIN(_, auraType, spellID, spellName, _, duration, _, _, _, _, unitCaster, test)
|
||||||
local arenaUnit = test and unitCaster or Gladdy:GetArenaUnit(unitCaster, true)
|
local arenaUnit = test and unitCaster or Gladdy:GetArenaUnit(unitCaster, true)
|
||||||
if not Gladdy.db.cooldownIconGlow or not arenaUnit or not Gladdy.buttons[arenaUnit] or auraType ~= AURA_TYPE_BUFF then
|
if not Gladdy.db.cooldownIconGlow or not arenaUnit or not Gladdy.buttons[arenaUnit] or auraType ~= AURA_TYPE_BUFF or spellID == 26889 then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
local cooldownFrame = Gladdy.buttons[arenaUnit].spellCooldownFrame
|
local cooldownFrame = Gladdy.buttons[arenaUnit].spellCooldownFrame
|
||||||
@ -412,22 +430,31 @@ function Cooldowns:AURA_GAIN(_, auraType, spellID, spellName, _, duration, _, _,
|
|||||||
|
|
||||||
for _,icon in pairs(cooldownFrame.icons) do
|
for _,icon in pairs(cooldownFrame.icons) do
|
||||||
if (icon.spellId == spellId) then
|
if (icon.spellId == spellId) then
|
||||||
if icon._ButtonGlow and not icon._ButtonGlow.animIn:IsPlaying() or not icon._ButtonGlow then
|
Gladdy:Debug("INFO", "Cooldowns:AURA_GAIN", "PixelGlow_Start", spellID)
|
||||||
LCG.ButtonGlow_Start(icon, nil, 0.15)
|
LCG.PixelGlow_Start(icon.glow, Gladdy:ColorAsArray(Gladdy.db.cooldownIconGlowColor), 12, 0.15, nil, 2)
|
||||||
C_Timer.NewTimer(duration, function() LCG.ButtonGlow_Stop(icon) end)
|
if icon.timer then
|
||||||
|
icon.timer:Cancel()
|
||||||
end
|
end
|
||||||
|
icon.timer = C_Timer.NewTimer(duration, function()
|
||||||
|
LCG.PixelGlow_Stop(icon.glow)
|
||||||
|
icon.timer:Cancel()
|
||||||
|
end)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function Cooldowns:AURA_FADE(unit, spellID)
|
function Cooldowns:AURA_FADE(unit, spellID)
|
||||||
if not Gladdy.buttons[unit] then
|
if not Gladdy.buttons[unit] or Gladdy.buttons[unit].stealthed then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
local cooldownFrame = Gladdy.buttons[unit].spellCooldownFrame
|
local cooldownFrame = Gladdy.buttons[unit].spellCooldownFrame
|
||||||
for _,icon in pairs(cooldownFrame.icons) do
|
for _,icon in pairs(cooldownFrame.icons) do
|
||||||
if (icon.spellId == spellID) then
|
if (icon.spellId == spellID) then
|
||||||
LCG.ButtonGlow_Stop(icon)
|
Gladdy:Debug("INFO", "Cooldowns:AURA_FADE", "LCG.ButtonGlow_Stop")
|
||||||
|
if icon.timer then
|
||||||
|
icon.timer:Cancel()
|
||||||
|
end
|
||||||
|
LCG.PixelGlow_Stop(icon.glow)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -437,12 +464,22 @@ end
|
|||||||
---------------------
|
---------------------
|
||||||
|
|
||||||
function Cooldowns:CooldownStart(button, spellId, duration, start)
|
function Cooldowns:CooldownStart(button, spellId, duration, start)
|
||||||
-- starts timer frame
|
|
||||||
if not duration or duration == nil or type(duration) ~= "number" then
|
if not duration or duration == nil or type(duration) ~= "number" then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
local cooldown = Gladdy:GetCooldownList()[button.class][spellId]
|
||||||
|
if type(cooldown) == "table" then
|
||||||
|
if (button.spec ~= nil and cooldown[button.spec] ~= nil) then
|
||||||
|
cooldown = cooldown[button.spec]
|
||||||
|
else
|
||||||
|
cooldown = cooldown.cd
|
||||||
|
end
|
||||||
|
end
|
||||||
for _,icon in pairs(button.spellCooldownFrame.icons) do
|
for _,icon in pairs(button.spellCooldownFrame.icons) do
|
||||||
if (icon.spellId == spellId) then
|
if (icon.spellId == spellId) then
|
||||||
|
if not start and icon.active and icon.timeLeft > cooldown/2 then
|
||||||
|
return -- do not trigger cooldown again
|
||||||
|
end
|
||||||
icon.active = true
|
icon.active = true
|
||||||
icon.timeLeft = start and start - GetTime() + duration or duration
|
icon.timeLeft = start and start - GetTime() + duration or duration
|
||||||
if (not Gladdy.db.cooldownDisableCircle) then icon.cooldown:SetCooldown(start or GetTime(), duration) end
|
if (not Gladdy.db.cooldownDisableCircle) then icon.cooldown:SetCooldown(start or GetTime(), duration) end
|
||||||
@ -452,7 +489,6 @@ function Cooldowns:CooldownStart(button, spellId, duration, start)
|
|||||||
if Gladdy.db.cooldownIconAlphaOnCooldown < 1 then
|
if Gladdy.db.cooldownIconAlphaOnCooldown < 1 then
|
||||||
icon.texture:SetAlpha(Gladdy.db.cooldownIconAlphaOnCooldown)
|
icon.texture:SetAlpha(Gladdy.db.cooldownIconAlphaOnCooldown)
|
||||||
end
|
end
|
||||||
--if math.random(1, 30 ) > 10 then LCG.ButtonGlow_Start(icon, nil, 0.15) end
|
|
||||||
icon:SetScript("OnUpdate", function(self, elapsed)
|
icon:SetScript("OnUpdate", function(self, elapsed)
|
||||||
self.timeLeft = self.timeLeft - elapsed
|
self.timeLeft = self.timeLeft - elapsed
|
||||||
local timeLeft = ceil(self.timeLeft)
|
local timeLeft = ceil(self.timeLeft)
|
||||||
@ -471,6 +507,7 @@ function Cooldowns:CooldownStart(button, spellId, duration, start)
|
|||||||
Cooldowns:CooldownReady(button, spellId, icon)
|
Cooldowns:CooldownReady(button, spellId, icon)
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
|
break
|
||||||
--C_VoiceChat.SpeakText(2, GetSpellInfo(spellId), 3, 4, 100)
|
--C_VoiceChat.SpeakText(2, GetSpellInfo(spellId), 3, 4, 100)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -487,7 +524,10 @@ local function resetIcon(icon)
|
|||||||
icon.cooldown:Hide()
|
icon.cooldown:Hide()
|
||||||
icon.cooldownFont:SetText("")
|
icon.cooldownFont:SetText("")
|
||||||
icon:SetScript("OnUpdate", nil)
|
icon:SetScript("OnUpdate", nil)
|
||||||
--LCG.ButtonGlow_Stop(icon)
|
if icon.timer then
|
||||||
|
icon.timer:Cancel()
|
||||||
|
end
|
||||||
|
LCG.PixelGlow_Stop(icon.glow)
|
||||||
end
|
end
|
||||||
|
|
||||||
function Cooldowns:CooldownReady(button, spellId, frame)
|
function Cooldowns:CooldownReady(button, spellId, frame)
|
||||||
@ -507,13 +547,11 @@ function Cooldowns:CooldownUsed(unit, unitClass, spellId, expirationTimeInSecond
|
|||||||
if not button then
|
if not button then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
-- if (self.db.cooldownList[spellId] == false) then return end
|
|
||||||
|
|
||||||
local cooldown = Gladdy:GetCooldownList()[unitClass][spellId]
|
local cooldown = Gladdy:GetCooldownList()[unitClass][spellId]
|
||||||
local cd = cooldown
|
local cd = cooldown
|
||||||
if (type(cooldown) == "table") then
|
if (type(cooldown) == "table") then
|
||||||
-- return if the spec doesn't have a cooldown for this spell
|
-- return if the spec doesn't have a cooldown for this spell
|
||||||
--if (arenaSpecs[unit] ~= nil and cooldown.notSpec ~= nil and arenaSpecs[unit] == cooldown.notSpec) then return end
|
|
||||||
if (button.spec ~= nil and cooldown.notSpec ~= nil and button.spec == cooldown.notSpec) then
|
if (button.spec ~= nil and cooldown.notSpec ~= nil and button.spec == cooldown.notSpec) then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
@ -526,7 +564,6 @@ function Cooldowns:CooldownUsed(unit, unitClass, spellId, expirationTimeInSecond
|
|||||||
end
|
end
|
||||||
|
|
||||||
-- check if there is a special cooldown for the units spec
|
-- check if there is a special cooldown for the units spec
|
||||||
--if (arenaSpecs[unit] ~= nil and cooldown[arenaSpecs[unit]] ~= nil) then
|
|
||||||
if (button.spec ~= nil and cooldown[button.spec] ~= nil) then
|
if (button.spec ~= nil and cooldown[button.spec] ~= nil) then
|
||||||
cd = cooldown[button.spec]
|
cd = cooldown[button.spec]
|
||||||
else
|
else
|
||||||
@ -601,7 +638,6 @@ function Cooldowns:AddCooldown(spellID, value, button)
|
|||||||
icon.texture:SetTexture(self.spellTextures[spellID])
|
icon.texture:SetTexture(self.spellTextures[spellID])
|
||||||
tinsert(button.spellCooldownFrame.icons, icon)
|
tinsert(button.spellCooldownFrame.icons, icon)
|
||||||
self:IconsSetPoint(button)
|
self:IconsSetPoint(button)
|
||||||
Gladdy:Debug("INFO", "Cooldowns:AddCooldown", button.unit, GetSpellInfo(spellID))
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -723,17 +759,10 @@ function Cooldowns:GetOptions()
|
|||||||
name = L["Cooldown"],
|
name = L["Cooldown"],
|
||||||
order = 2,
|
order = 2,
|
||||||
},
|
},
|
||||||
cooldownIconGlow = Gladdy:option({
|
|
||||||
type = "toggle",
|
|
||||||
name = L["Glow Icon"],
|
|
||||||
desc = L["Glow the icon when cooldown active"],
|
|
||||||
order = 3,
|
|
||||||
width = "full",
|
|
||||||
}),
|
|
||||||
cooldownIconDesaturateOnCooldown = Gladdy:option({
|
cooldownIconDesaturateOnCooldown = Gladdy:option({
|
||||||
type = "toggle",
|
type = "toggle",
|
||||||
name = L["Desaturate Icon"],
|
name = L["Desaturate Icon"],
|
||||||
order = 4,
|
order = 5,
|
||||||
width = "full",
|
width = "full",
|
||||||
}),
|
}),
|
||||||
cooldownIconAlphaOnCooldown = Gladdy:option({
|
cooldownIconAlphaOnCooldown = Gladdy:option({
|
||||||
@ -741,7 +770,7 @@ function Cooldowns:GetOptions()
|
|||||||
name = L["Cooldown alpha on CD"],
|
name = L["Cooldown alpha on CD"],
|
||||||
desc = L["Alpha of the icon when cooldown active"],
|
desc = L["Alpha of the icon when cooldown active"],
|
||||||
desc = L["changes "],
|
desc = L["changes "],
|
||||||
order = 5,
|
order = 6,
|
||||||
min = 0,
|
min = 0,
|
||||||
max = 1,
|
max = 1,
|
||||||
step = 0.1,
|
step = 0.1,
|
||||||
@ -750,12 +779,12 @@ function Cooldowns:GetOptions()
|
|||||||
headerCircle = {
|
headerCircle = {
|
||||||
type = "header",
|
type = "header",
|
||||||
name = L["Cooldowncircle"],
|
name = L["Cooldowncircle"],
|
||||||
order = 6,
|
order = 10,
|
||||||
},
|
},
|
||||||
cooldownDisableCircle = Gladdy:option({
|
cooldownDisableCircle = Gladdy:option({
|
||||||
type = "toggle",
|
type = "toggle",
|
||||||
name = L["No Cooldown Circle"],
|
name = L["No Cooldown Circle"],
|
||||||
order = 8,
|
order = 11,
|
||||||
width = "full",
|
width = "full",
|
||||||
}),
|
}),
|
||||||
cooldownCooldownAlpha = Gladdy:option({
|
cooldownCooldownAlpha = Gladdy:option({
|
||||||
@ -764,7 +793,7 @@ function Cooldowns:GetOptions()
|
|||||||
min = 0,
|
min = 0,
|
||||||
max = 1,
|
max = 1,
|
||||||
step = 0.1,
|
step = 0.1,
|
||||||
order = 9,
|
order = 12,
|
||||||
width = "full",
|
width = "full",
|
||||||
}),
|
}),
|
||||||
cooldownCooldownNumberAlpha = {
|
cooldownCooldownNumberAlpha = {
|
||||||
@ -773,7 +802,7 @@ function Cooldowns:GetOptions()
|
|||||||
min = 0,
|
min = 0,
|
||||||
max = 1,
|
max = 1,
|
||||||
step = 0.1,
|
step = 0.1,
|
||||||
order = 10,
|
order = 13,
|
||||||
width = "full",
|
width = "full",
|
||||||
set = function(info, value)
|
set = function(info, value)
|
||||||
Gladdy.db.cooldownFontColor.a = value
|
Gladdy.db.cooldownFontColor.a = value
|
||||||
@ -785,10 +814,48 @@ function Cooldowns:GetOptions()
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
glow = {
|
||||||
|
type = "group",
|
||||||
|
name = L["Glow"],
|
||||||
|
order = 3,
|
||||||
|
args = {
|
||||||
|
header = {
|
||||||
|
type = "header",
|
||||||
|
name = L["Glow"],
|
||||||
|
order = 1,
|
||||||
|
},
|
||||||
|
cooldownIconGlow = Gladdy:option({
|
||||||
|
type = "toggle",
|
||||||
|
name = L["Glow Icon"],
|
||||||
|
desc = L["Glow the icon when cooldown active"],
|
||||||
|
order = 2,
|
||||||
|
width = "full",
|
||||||
|
}),
|
||||||
|
cooldownIconGlowColor = Gladdy:colorOption({
|
||||||
|
disabled = function() return not Gladdy.db.cooldownIconGlow end,
|
||||||
|
type = "color",
|
||||||
|
hasAlpha = true,
|
||||||
|
name = L["Glow color"],
|
||||||
|
desc = L["Color of the glow"],
|
||||||
|
order = 3,
|
||||||
|
width = "full",
|
||||||
|
}),
|
||||||
|
resetGlow = {
|
||||||
|
type = "execute",
|
||||||
|
name = L["Reset Glow"],
|
||||||
|
desc = L["Reset Glow Color"],
|
||||||
|
func = function()
|
||||||
|
Gladdy.db.cooldownIconGlowColor = {r = 0.95, g = 0.95, b = 0.32, a = 1}
|
||||||
|
Gladdy:UpdateFrame()
|
||||||
|
end,
|
||||||
|
order = 3,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
},
|
||||||
font = {
|
font = {
|
||||||
type = "group",
|
type = "group",
|
||||||
name = L["Font"],
|
name = L["Font"],
|
||||||
order = 3,
|
order = 4,
|
||||||
args = {
|
args = {
|
||||||
header = {
|
header = {
|
||||||
type = "header",
|
type = "header",
|
||||||
@ -825,7 +892,7 @@ function Cooldowns:GetOptions()
|
|||||||
position = {
|
position = {
|
||||||
type = "group",
|
type = "group",
|
||||||
name = L["Position"],
|
name = L["Position"],
|
||||||
order = 5,
|
order = 6,
|
||||||
args = {
|
args = {
|
||||||
header = {
|
header = {
|
||||||
type = "header",
|
type = "header",
|
||||||
@ -889,7 +956,7 @@ function Cooldowns:GetOptions()
|
|||||||
border = {
|
border = {
|
||||||
type = "group",
|
type = "group",
|
||||||
name = L["Border"],
|
name = L["Border"],
|
||||||
order = 4,
|
order = 5,
|
||||||
args = {
|
args = {
|
||||||
header = {
|
header = {
|
||||||
type = "header",
|
type = "header",
|
||||||
@ -914,7 +981,7 @@ function Cooldowns:GetOptions()
|
|||||||
frameStrata = {
|
frameStrata = {
|
||||||
type = "group",
|
type = "group",
|
||||||
name = L["Frame Strata and Level"],
|
name = L["Frame Strata and Level"],
|
||||||
order = 6,
|
order = 7,
|
||||||
args = {
|
args = {
|
||||||
headerAuraLevel = {
|
headerAuraLevel = {
|
||||||
type = "header",
|
type = "header",
|
||||||
|
@ -7,7 +7,6 @@ local CreateFrame = CreateFrame
|
|||||||
local GetTime = GetTime
|
local GetTime = GetTime
|
||||||
|
|
||||||
local Gladdy = LibStub("Gladdy")
|
local Gladdy = LibStub("Gladdy")
|
||||||
--local DRData = LibStub("DRData-1.0-BCC")
|
|
||||||
local DRData = LibStub("DRList-1.0")
|
local DRData = LibStub("DRList-1.0")
|
||||||
local L = Gladdy.L
|
local L = Gladdy.L
|
||||||
local function defaultCategories()
|
local function defaultCategories()
|
||||||
@ -295,13 +294,13 @@ function Diminishings:UpdateFrame(unit)
|
|||||||
|
|
||||||
if Gladdy.db.drIconZoomed then
|
if Gladdy.db.drIconZoomed then
|
||||||
if icon.texture.masked then
|
if icon.texture.masked then
|
||||||
icon.texture:SetMask(nil)
|
icon.texture:SetMask("")
|
||||||
icon.texture:SetTexCoord(0.1,0.9,0.1,0.9)
|
icon.texture:SetTexCoord(0.1,0.9,0.1,0.9)
|
||||||
icon.texture.masked = nil
|
icon.texture.masked = nil
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if not icon.texture.masked then
|
if not icon.texture.masked then
|
||||||
icon.texture:SetMask(nil)
|
icon.texture:SetMask("")
|
||||||
icon.texture:SetTexCoord(0,1,0,1)
|
icon.texture:SetTexCoord(0,1,0,1)
|
||||||
icon.texture:SetMask("Interface\\AddOns\\Gladdy\\Images\\mask")
|
icon.texture:SetMask("Interface\\AddOns\\Gladdy\\Images\\mask")
|
||||||
icon.texture.masked = true
|
icon.texture.masked = true
|
||||||
|
@ -79,7 +79,7 @@ function Healthbar:CreateFrame(unit)
|
|||||||
healthBar.bg:SetAlpha(1)
|
healthBar.bg:SetAlpha(1)
|
||||||
healthBar.bg:SetVertexColor(Gladdy:SetColor(Gladdy.db.healthBarBgColor))
|
healthBar.bg:SetVertexColor(Gladdy:SetColor(Gladdy.db.healthBarBgColor))
|
||||||
|
|
||||||
healthBar.nameText = healthBar:CreateFontString(nil, "LOW", "GameFontNormalSmall")
|
healthBar.nameText = healthBar:CreateFontString(nil, "OVERLAY", "GameFontNormalSmall")
|
||||||
if (Gladdy.db.healthBarNameFontSize < 1) then
|
if (Gladdy.db.healthBarNameFontSize < 1) then
|
||||||
healthBar.nameText:SetFont(Gladdy:SMFetch("font", "healthBarNameFont"), 1)
|
healthBar.nameText:SetFont(Gladdy:SMFetch("font", "healthBarNameFont"), 1)
|
||||||
healthBar.nameText:Hide()
|
healthBar.nameText:Hide()
|
||||||
@ -93,7 +93,7 @@ function Healthbar:CreateFrame(unit)
|
|||||||
healthBar.nameText:SetJustifyH("CENTER")
|
healthBar.nameText:SetJustifyH("CENTER")
|
||||||
healthBar.nameText:SetPoint("LEFT", Gladdy.db.healthTextLeftHOffset, Gladdy.db.healthTextLeftVOffset)
|
healthBar.nameText:SetPoint("LEFT", Gladdy.db.healthTextLeftHOffset, Gladdy.db.healthTextLeftVOffset)
|
||||||
|
|
||||||
healthBar.healthText = healthBar:CreateFontString(nil, "LOW")
|
healthBar.healthText = healthBar:CreateFontString(nil, "OVERLAY")
|
||||||
if (Gladdy.db.healthBarHealthFontSize < 1) then
|
if (Gladdy.db.healthBarHealthFontSize < 1) then
|
||||||
healthBar.healthText:SetFont(Gladdy:SMFetch("font", "healthBarFont"), 1)
|
healthBar.healthText:SetFont(Gladdy:SMFetch("font", "healthBarFont"), 1)
|
||||||
healthBar.healthText:Hide()
|
healthBar.healthText:Hide()
|
||||||
@ -146,7 +146,6 @@ local function getGradient(start, ending, percentage, factor)
|
|||||||
return start * abs(-2 * percentage + 1) + ending * factor
|
return start * abs(-2 * percentage + 1) + ending * factor
|
||||||
end
|
end
|
||||||
|
|
||||||
-- /run LibStub("Gladdy").modules["Health Bar"]:SetHealthStatusBarColor("arena1", 51, 100)
|
|
||||||
local rMax, gMax, bMax, rMid, gMid, bMid, rMin, gMin, bMin, rNow, gNow, bNow, percentage, factor, stealthAlpha
|
local rMax, gMax, bMax, rMid, gMid, bMid, rMin, gMin, bMin, rNow, gNow, bNow, percentage, factor, stealthAlpha
|
||||||
function Healthbar:SetHealthStatusBarColor(unit, health, healthMax)
|
function Healthbar:SetHealthStatusBarColor(unit, health, healthMax)
|
||||||
local button = Gladdy.buttons[unit]
|
local button = Gladdy.buttons[unit]
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
local string_gsub, floor, pairs = string.gsub, math.floor, pairs
|
local string_gsub, floor, pairs = string.gsub, math.floor, pairs
|
||||||
local CreateFrame, SetPortraitTexture = CreateFrame, SetPortraitTexture
|
local CreateFrame, SetPortraitTexture = CreateFrame, SetPortraitTexture
|
||||||
local UnitHealthMax, UnitHealth, UnitGUID = UnitHealthMax, UnitHealth, UnitGUID
|
local UnitHealthMax, UnitHealth, UnitGUID, UnitExists = UnitHealthMax, UnitHealth, UnitGUID, UnitExists
|
||||||
|
|
||||||
local Gladdy = LibStub("Gladdy")
|
local Gladdy = LibStub("Gladdy")
|
||||||
local L = Gladdy.L
|
local L = Gladdy.L
|
||||||
@ -47,6 +47,7 @@ function Pets:UpdateFrameOnce()
|
|||||||
self:RegisterMessage("PET_DESTROYED")
|
self:RegisterMessage("PET_DESTROYED")
|
||||||
self:RegisterMessage("PET_STEALTH")
|
self:RegisterMessage("PET_STEALTH")
|
||||||
self:RegisterMessage("ENEMY_SPOTTED")
|
self:RegisterMessage("ENEMY_SPOTTED")
|
||||||
|
self:RegisterMessage("UNIT_DEATH")
|
||||||
else
|
else
|
||||||
self:UnregisterAllMessages()
|
self:UnregisterAllMessages()
|
||||||
end
|
end
|
||||||
@ -56,6 +57,11 @@ function Pets:JOINED_ARENA()
|
|||||||
for _,v in pairs(self.frames) do
|
for _,v in pairs(self.frames) do
|
||||||
v.healthBar:SetAlpha(0)
|
v.healthBar:SetAlpha(0)
|
||||||
end
|
end
|
||||||
|
for i=1,Gladdy.curBracket do
|
||||||
|
if UnitExists("arenapet" .. i) then
|
||||||
|
Gladdy:SendMessage("PET_SPOTTED", "arenapet" .. i)
|
||||||
|
end
|
||||||
|
end
|
||||||
if Gladdy.db.petEnabled then
|
if Gladdy.db.petEnabled then
|
||||||
self:RegisterEvent("UNIT_PET")
|
self:RegisterEvent("UNIT_PET")
|
||||||
self:SetScript("OnEvent", function(_, event, unitId)
|
self:SetScript("OnEvent", function(_, event, unitId)
|
||||||
@ -77,6 +83,7 @@ function Pets:ResetUnit(unitId)
|
|||||||
end
|
end
|
||||||
petFrame.healthBar:SetAlpha(0)
|
petFrame.healthBar:SetAlpha(0)
|
||||||
petFrame.healthBar:SetScript("OnUpdate", nil)
|
petFrame.healthBar:SetScript("OnUpdate", nil)
|
||||||
|
petFrame.healthBar.portrait:SetTexture(nil)
|
||||||
self:UnregisterEvent("UNIT_PET")
|
self:UnregisterEvent("UNIT_PET")
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -90,15 +97,20 @@ function Pets:PET_SPOTTED(unit)
|
|||||||
Pets:SetHealthText(self, UnitHealth(unit), UnitHealthMax(unit))
|
Pets:SetHealthText(self, UnitHealth(unit), UnitHealthMax(unit))
|
||||||
end)
|
end)
|
||||||
end
|
end
|
||||||
|
Gladdy:Print(self.frames[unit].healthBar:GetAlpha())
|
||||||
end
|
end
|
||||||
|
|
||||||
function Pets:PET_DESTROYED(unit)
|
function Pets:PET_DESTROYED(unit)
|
||||||
if Gladdy.db.petEnabled then
|
if Gladdy.db.petEnabled and self.frames[unit] then
|
||||||
self.frames[unit].healthBar:SetAlpha(0)
|
self.frames[unit].healthBar:SetAlpha(0)
|
||||||
self.frames[unit].healthBar:SetScript("OnUpdate", nil)
|
self.frames[unit].healthBar:SetScript("OnUpdate", nil)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function Pets:UNIT_DEATH(unit)
|
||||||
|
self:PET_DESTROYED(unit)
|
||||||
|
end
|
||||||
|
|
||||||
function Pets:PET_STEALTH(unit)
|
function Pets:PET_STEALTH(unit)
|
||||||
if Gladdy.db.petEnabled then
|
if Gladdy.db.petEnabled then
|
||||||
self.frames[unit].healthBar.hp:SetStatusBarColor(0.66, 0.66, 0.66, 1)
|
self.frames[unit].healthBar.hp:SetStatusBarColor(0.66, 0.66, 0.66, 1)
|
||||||
@ -122,6 +134,7 @@ function Pets:CheckUnitPet(unitId)
|
|||||||
petFrame.healthBar.hp:SetMinMaxValues(0, UnitHealthMax(unit))
|
petFrame.healthBar.hp:SetMinMaxValues(0, UnitHealthMax(unit))
|
||||||
petFrame.healthBar.hp:SetValue(UnitHealth(unit))
|
petFrame.healthBar.hp:SetValue(UnitHealth(unit))
|
||||||
Pets:SetHealthText(petFrame.healthBar, UnitHealth(unit), UnitHealthMax(unit))
|
Pets:SetHealthText(petFrame.healthBar, UnitHealth(unit), UnitHealthMax(unit))
|
||||||
|
SetPortraitTexture(petFrame.healthBar.portrait, unit)
|
||||||
petFrame.healthBar:SetScript("OnUpdate", function(self)
|
petFrame.healthBar:SetScript("OnUpdate", function(self)
|
||||||
self.hp:SetValue(UnitHealth(self.unit))
|
self.hp:SetValue(UnitHealth(self.unit))
|
||||||
Pets:SetHealthText(self, UnitHealth(unit), UnitHealthMax(unit))
|
Pets:SetHealthText(self, UnitHealth(unit), UnitHealthMax(unit))
|
||||||
@ -202,7 +215,7 @@ function Pets:CreateFrame(unitId)
|
|||||||
healthBar.bg:SetAlpha(1)
|
healthBar.bg:SetAlpha(1)
|
||||||
healthBar.bg:SetVertexColor(Gladdy:SetColor(Gladdy.db.petHealthBarBgColor))
|
healthBar.bg:SetVertexColor(Gladdy:SetColor(Gladdy.db.petHealthBarBgColor))
|
||||||
|
|
||||||
healthBar.nameText = healthBar:CreateFontString(nil, "LOW", "GameFontNormalSmall")
|
healthBar.nameText = healthBar:CreateFontString(nil, "OVERLAY", "GameFontNormalSmall")
|
||||||
if (Gladdy.db.petHealthBarFontSize < 1) then
|
if (Gladdy.db.petHealthBarFontSize < 1) then
|
||||||
healthBar.nameText:SetFont(Gladdy:SMFetch("font", "petHealthBarFont"), 1)
|
healthBar.nameText:SetFont(Gladdy:SMFetch("font", "petHealthBarFont"), 1)
|
||||||
healthBar.nameText:Hide()
|
healthBar.nameText:Hide()
|
||||||
@ -216,7 +229,7 @@ function Pets:CreateFrame(unitId)
|
|||||||
healthBar.nameText:SetJustifyH("CENTER")
|
healthBar.nameText:SetJustifyH("CENTER")
|
||||||
healthBar.nameText:SetPoint("LEFT", 5, 0)
|
healthBar.nameText:SetPoint("LEFT", 5, 0)
|
||||||
|
|
||||||
healthBar.healthText = healthBar:CreateFontString(nil, "LOW")
|
healthBar.healthText = healthBar:CreateFontString(nil, "OVERLAY")
|
||||||
if (Gladdy.db.petHealthBarFontSize < 1) then
|
if (Gladdy.db.petHealthBarFontSize < 1) then
|
||||||
healthBar.healthText:SetFont(Gladdy:SMFetch("font", "petHealthBarFont"), 1)
|
healthBar.healthText:SetFont(Gladdy:SMFetch("font", "petHealthBarFont"), 1)
|
||||||
healthBar.healthText:Hide()
|
healthBar.healthText:Hide()
|
||||||
@ -346,7 +359,7 @@ function Pets:SetHealthText(healthBar, health, healthMax)
|
|||||||
healthText = ("%d%%"):format(healthPercentage)
|
healthText = ("%d%%"):format(healthPercentage)
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
healthText = "DEAD"
|
healthText = ""
|
||||||
end
|
end
|
||||||
|
|
||||||
healthBar.healthText:SetText(healthText)
|
healthBar.healthText:SetText(healthText)
|
||||||
|
@ -81,7 +81,7 @@ function Powerbar:CreateFrame(unit)
|
|||||||
powerBar.bg:SetAllPoints(powerBar.energy)
|
powerBar.bg:SetAllPoints(powerBar.energy)
|
||||||
powerBar.bg:SetVertexColor(Gladdy:SetColor(Gladdy.db.powerBarBgColor))
|
powerBar.bg:SetVertexColor(Gladdy:SetColor(Gladdy.db.powerBarBgColor))
|
||||||
|
|
||||||
powerBar.raceText = powerBar:CreateFontString(nil, "LOW")
|
powerBar.raceText = powerBar:CreateFontString(nil, "OVERLAY")
|
||||||
powerBar.raceText:SetFont(Gladdy:SMFetch("font", "powerBarFont"), Gladdy.db.powerBarRaceFontSize, Gladdy.db.powerTextLeftOutline and "OUTLINE")
|
powerBar.raceText:SetFont(Gladdy:SMFetch("font", "powerBarFont"), Gladdy.db.powerBarRaceFontSize, Gladdy.db.powerTextLeftOutline and "OUTLINE")
|
||||||
powerBar.raceText:SetTextColor(Gladdy:SetColor(Gladdy.db.powerBarFontColor))
|
powerBar.raceText:SetTextColor(Gladdy:SetColor(Gladdy.db.powerBarFontColor))
|
||||||
powerBar.raceText:SetShadowOffset(1, -1)
|
powerBar.raceText:SetShadowOffset(1, -1)
|
||||||
@ -89,7 +89,7 @@ function Powerbar:CreateFrame(unit)
|
|||||||
powerBar.raceText:SetJustifyH("CENTER")
|
powerBar.raceText:SetJustifyH("CENTER")
|
||||||
powerBar.raceText:SetPoint("LEFT", Gladdy.db.powerTextLeftHOffset, Gladdy.db.powerTextLeftVOffset)
|
powerBar.raceText:SetPoint("LEFT", Gladdy.db.powerTextLeftHOffset, Gladdy.db.powerTextLeftVOffset)
|
||||||
|
|
||||||
powerBar.powerText = powerBar:CreateFontString(nil, "LOW")
|
powerBar.powerText = powerBar:CreateFontString(nil, "OVERLAY")
|
||||||
powerBar.powerText:SetFont(Gladdy:SMFetch("font", "powerBarFont"), Gladdy.db.powerBarPowerFontSize, Gladdy.db.powerTextRightOutline and "OUTLINE")
|
powerBar.powerText:SetFont(Gladdy:SMFetch("font", "powerBarFont"), Gladdy.db.powerBarPowerFontSize, Gladdy.db.powerTextRightOutline and "OUTLINE")
|
||||||
powerBar.powerText:SetTextColor(Gladdy:SetColor(Gladdy.db.powerBarFontColor))
|
powerBar.powerText:SetTextColor(Gladdy:SetColor(Gladdy.db.powerBarFontColor))
|
||||||
powerBar.powerText:SetShadowOffset(1, -1)
|
powerBar.powerText:SetShadowOffset(1, -1)
|
||||||
|
@ -169,13 +169,13 @@ function Racial:UpdateFrame(unit)
|
|||||||
|
|
||||||
if Gladdy.db.racialIconZoomed then
|
if Gladdy.db.racialIconZoomed then
|
||||||
if racial.texture.masked then
|
if racial.texture.masked then
|
||||||
racial.texture:SetMask(nil)
|
racial.texture:SetMask("")
|
||||||
racial.texture:SetTexCoord(0.1,0.9,0.1,0.9)
|
racial.texture:SetTexCoord(0.1,0.9,0.1,0.9)
|
||||||
racial.texture.masked = nil
|
racial.texture.masked = nil
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if not racial.texture.masked then
|
if not racial.texture.masked then
|
||||||
racial.texture:SetMask(nil)
|
racial.texture:SetMask("")
|
||||||
racial.texture:SetTexCoord(0,1,0,1)
|
racial.texture:SetTexCoord(0,1,0,1)
|
||||||
racial.texture:SetMask("Interface\\AddOns\\Gladdy\\Images\\mask")
|
racial.texture:SetMask("Interface\\AddOns\\Gladdy\\Images\\mask")
|
||||||
racial.texture.masked = true
|
racial.texture.masked = true
|
||||||
|
@ -357,8 +357,6 @@ function RangeCheck:GetSpells()
|
|||||||
end,
|
end,
|
||||||
set = function(_, value)
|
set = function(_, value)
|
||||||
Gladdy.db.rangeCheckDefaultSpells[class].min = tonumber(value)
|
Gladdy.db.rangeCheckDefaultSpells[class].min = tonumber(value)
|
||||||
--Gladdy.options.args["Range Check"].args.oorSpells.args[class].args.min.name = GetSpellInfo(Gladdy.db.rangeCheckDefaultSpells[class].min) and format("|T%s:20|t %s", select(3, GetSpellInfo(Gladdy.db.rangeCheckDefaultSpells[class].min)), select(1, GetSpellInfo(Gladdy.db.rangeCheckDefaultSpells[class].min)))
|
|
||||||
-- or "nil"
|
|
||||||
Gladdy.options.args["Range Check"].args.oorSpells.args[class].args.headerMin.name = GetSpellInfo(Gladdy.db.rangeCheckDefaultSpells[class].min) and format("|T%s:20|t %s - %d" .. L["yds"], select(3, GetSpellInfo(Gladdy.db.rangeCheckDefaultSpells[class].min)), select(1, GetSpellInfo(Gladdy.db.rangeCheckDefaultSpells[class].min)), select(6, GetSpellInfo(Gladdy.db.rangeCheckDefaultSpells[class].min)))
|
Gladdy.options.args["Range Check"].args.oorSpells.args[class].args.headerMin.name = GetSpellInfo(Gladdy.db.rangeCheckDefaultSpells[class].min) and format("|T%s:20|t %s - %d" .. L["yds"], select(3, GetSpellInfo(Gladdy.db.rangeCheckDefaultSpells[class].min)), select(1, GetSpellInfo(Gladdy.db.rangeCheckDefaultSpells[class].min)), select(6, GetSpellInfo(Gladdy.db.rangeCheckDefaultSpells[class].min)))
|
||||||
or "nil"
|
or "nil"
|
||||||
end
|
end
|
||||||
|
@ -25,9 +25,6 @@ local ShadowsightTimer = Gladdy:NewModule("Shadowsight Timer", nil, {
|
|||||||
shadowsightTimerFrameLevel = 20,
|
shadowsightTimerFrameLevel = 20,
|
||||||
})
|
})
|
||||||
|
|
||||||
-- /run LibStub("Gladdy").modules["Shadowsight Timer"]:AURA_GAIN(nil, nil, 34709)
|
|
||||||
-- /run LibStub("Gladdy").modules["Shadowsight Timer"].timerFrame1:SetAlpha(0)
|
|
||||||
|
|
||||||
function ShadowsightTimer:OnEvent(event, ...)
|
function ShadowsightTimer:OnEvent(event, ...)
|
||||||
self[event](self, ...)
|
self[event](self, ...)
|
||||||
end
|
end
|
||||||
|
@ -203,13 +203,15 @@ end
|
|||||||
function TotemPlates:NAME_PLATE_UNIT_REMOVED(unitID)
|
function TotemPlates:NAME_PLATE_UNIT_REMOVED(unitID)
|
||||||
local nameplate = C_NamePlate.GetNamePlateForUnit(unitID)
|
local nameplate = C_NamePlate.GetNamePlateForUnit(unitID)
|
||||||
self.activeTotemNameplates[unitID] = nil
|
self.activeTotemNameplates[unitID] = nil
|
||||||
--self:ToggleAddon(nameplate, true)
|
|
||||||
if nameplate.gladdyTotemFrame then
|
if nameplate.gladdyTotemFrame then
|
||||||
nameplate.gladdyTotemFrame:Hide()
|
nameplate.gladdyTotemFrame:Hide()
|
||||||
nameplate.gladdyTotemFrame:SetParent(nil)
|
nameplate.gladdyTotemFrame:SetParent(nil)
|
||||||
tinsert(self.totemPlateCache, nameplate.gladdyTotemFrame)
|
tinsert(self.totemPlateCache, nameplate.gladdyTotemFrame)
|
||||||
nameplate.gladdyTotemFrame = nil
|
nameplate.gladdyTotemFrame = nil
|
||||||
end
|
end
|
||||||
|
if (self.addon == "ElvUI") then
|
||||||
|
self:ToggleAddon(nameplate, true)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
---------------------------------------------------
|
---------------------------------------------------
|
||||||
@ -373,12 +375,26 @@ function TotemPlates:ToggleAddon(nameplate, show)
|
|||||||
local addonFrames = { self:GetAddonFrame(nameplate) }
|
local addonFrames = { self:GetAddonFrame(nameplate) }
|
||||||
if addonFrames and #addonFrames > 0 then
|
if addonFrames and #addonFrames > 0 then
|
||||||
if show then
|
if show then
|
||||||
for _,v in ipairs(addonFrames) do
|
for _, frame in ipairs(addonFrames) do
|
||||||
v:Show()
|
if frame.UpdateAllElements then
|
||||||
|
Gladdy:Debug("INFO", "TotemPlates:ToggleAddon - NAME_PLATE_UNIT_ADDED - nameplate.unitFrame:UpdateAllElements")
|
||||||
|
frame:Show()
|
||||||
|
frame:UpdateAllElements("NAME_PLATE_UNIT_ADDED")
|
||||||
|
else
|
||||||
|
Gladdy:Debug("INFO", "TotemPlates:ToggleAddon - NAME_PLATE_UNIT_ADDED - Show")
|
||||||
|
frame:Show()
|
||||||
|
end
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
for _,v in ipairs(addonFrames) do
|
for _, frame in ipairs(addonFrames) do
|
||||||
v:Hide()
|
if frame.UpdateAllElements then
|
||||||
|
Gladdy:Debug("INFO", "TotemPlates:ToggleAddon - NAME_PLATE_UNIT_REMOVED - nameplate.unitFrame:UpdateAllElements")
|
||||||
|
frame:UpdateAllElements("NAME_PLATE_UNIT_REMOVED")
|
||||||
|
frame:Hide()
|
||||||
|
else
|
||||||
|
Gladdy:Debug("INFO", "TotemPlates:ToggleAddon - NAME_PLATE_UNIT_REMOVED - Hide")
|
||||||
|
frame:Hide()
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -390,7 +406,7 @@ function TotemPlates.OnUpdate(self)
|
|||||||
else
|
else
|
||||||
self.selectionHighlight:SetAlpha(0)
|
self.selectionHighlight:SetAlpha(0)
|
||||||
end
|
end
|
||||||
if (TotemPlates.addon == "Plater" or TotemPlates.addon == "Tukui" or TotemPlates.addon == "ElvUI") and self.parent and self.parent.unitFrame then
|
if (TotemPlates.addon == "Plater" or TotemPlates.addon == "Tukui") and self.parent and self.parent.unitFrame then
|
||||||
self.parent.unitFrame:Hide()
|
self.parent.unitFrame:Hide()
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -442,7 +458,7 @@ function TotemPlates:OnUnitEvent(unitID)
|
|||||||
nameplate.gladdyTotemFrame.parent = nameplate
|
nameplate.gladdyTotemFrame.parent = nameplate
|
||||||
nameplate.gladdyTotemFrame:Show()
|
nameplate.gladdyTotemFrame:Show()
|
||||||
TotemPlates:SetTotemAlpha(nameplate.gladdyTotemFrame, unitID)
|
TotemPlates:SetTotemAlpha(nameplate.gladdyTotemFrame, unitID)
|
||||||
self:ToggleAddon(nameplate)
|
self:ToggleAddon(nameplate, false)
|
||||||
self.activeTotemNameplates[unitID] = nameplate
|
self.activeTotemNameplates[unitID] = nameplate
|
||||||
elseif totemDataEntry and not Gladdy.db.npTotemColors["totem" .. totemDataEntry.id].enabled and Gladdy.db.npTotemsHideDisabledTotems then
|
elseif totemDataEntry and not Gladdy.db.npTotemColors["totem" .. totemDataEntry.id].enabled and Gladdy.db.npTotemsHideDisabledTotems then
|
||||||
if nameplate.gladdyTotemFrame then
|
if nameplate.gladdyTotemFrame then
|
||||||
@ -451,7 +467,7 @@ function TotemPlates:OnUnitEvent(unitID)
|
|||||||
tinsert(self.totemPlateCache, nameplate.gladdyTotemFrame)
|
tinsert(self.totemPlateCache, nameplate.gladdyTotemFrame)
|
||||||
nameplate.gladdyTotemFrame = nil
|
nameplate.gladdyTotemFrame = nil
|
||||||
end
|
end
|
||||||
self:ToggleAddon(nameplate)
|
self:ToggleAddon(nameplate, false)
|
||||||
else
|
else
|
||||||
self:ToggleAddon(nameplate, true)
|
self:ToggleAddon(nameplate, true)
|
||||||
end
|
end
|
||||||
|
@ -182,13 +182,13 @@ function Trinket:UpdateFrame(unit)
|
|||||||
|
|
||||||
if Gladdy.db.trinketIconZoomed then
|
if Gladdy.db.trinketIconZoomed then
|
||||||
if trinket.texture.masked then
|
if trinket.texture.masked then
|
||||||
trinket.texture:SetMask(nil)
|
trinket.texture:SetMask("")
|
||||||
trinket.texture:SetTexCoord(0.1,0.9,0.1,0.9)
|
trinket.texture:SetTexCoord(0.1,0.9,0.1,0.9)
|
||||||
trinket.texture.masked = nil
|
trinket.texture.masked = nil
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if not trinket.texture.masked then
|
if not trinket.texture.masked then
|
||||||
trinket.texture:SetMask(nil)
|
trinket.texture:SetMask("")
|
||||||
trinket.texture:SetTexCoord(0,1,0,1)
|
trinket.texture:SetTexCoord(0,1,0,1)
|
||||||
trinket.texture:SetMask("Interface\\AddOns\\Gladdy\\Images\\mask")
|
trinket.texture:SetMask("Interface\\AddOns\\Gladdy\\Images\\mask")
|
||||||
trinket.texture.masked = true
|
trinket.texture.masked = true
|
||||||
|
50
README.md
50
README.md
@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
## [v2.20-Beta Download Here](https://github.com/XiconQoo/Gladdy-TBC/releases/download/v2.20-Release/Gladdy_Classic_v2.20-Beta.zip)
|
## [v2.27-Release Download Here](https://github.com/XiconQoo/Gladdy-TBC/releases/download/v2.27-Release/Gladdy_Classic_v2.27-Release.zip)
|
||||||
|
|
||||||
###### <a target="_blank" rel="noopener noreferrer" href="https://www.paypal.me/xiconqoo/10"><img src="https://raw.githubusercontent.com/XiconQoo/Gladdy/readme-media/Paypal-Donate.png" height="30" style="margin-top:-30px;position:relative;top:20px;"></a> Please consider donating if you like my work
|
###### <a target="_blank" rel="noopener noreferrer" href="https://www.paypal.me/xiconqoo/10"><img src="https://raw.githubusercontent.com/XiconQoo/Gladdy/readme-media/Paypal-Donate.png" height="30" style="margin-top:-30px;position:relative;top:20px;"></a> Please consider donating if you like my work
|
||||||
|
|
||||||
@ -55,11 +55,13 @@ The goal is to make Gladdy highly configurable in it's appearance. Everything ca
|
|||||||
|
|
||||||
## Contributors
|
## Contributors
|
||||||
|
|
||||||
|
- [XyzKangUI](https://github.com/XyzKangUI)
|
||||||
- [ManneN1](https://github.com/ManneN1)
|
- [ManneN1](https://github.com/ManneN1)
|
||||||
- [AlexFolland](https://github.com/AlexFolland)
|
- [AlexFolland](https://github.com/AlexFolland)
|
||||||
- [dfherr](https://github.com/dfherr)
|
- [dfherr](https://github.com/dfherr)
|
||||||
- [miraage](https://github.com/miraage)
|
- [miraage](https://github.com/miraage)
|
||||||
- [veiz](https://github.com/veiz)
|
- [veiz](https://github.com/veiz)
|
||||||
|
- [Flamanis](https://github.com/Flamanis)
|
||||||
|
|
||||||
Thank you!
|
Thank you!
|
||||||
|
|
||||||
@ -79,6 +81,52 @@ Thank you!
|
|||||||
|
|
||||||
### Changes
|
### Changes
|
||||||
|
|
||||||
|
### v2.27-Release
|
||||||
|
- fix TotemPlates interfering with NeatPlates
|
||||||
|
|
||||||
|
### v2.26-Release
|
||||||
|
- fix TotemPlates interfering with Plater (thanks again [Flamanis](https://github.com/Flamanis))
|
||||||
|
|
||||||
|
### v2.25-Release
|
||||||
|
- fix TotemPlates interfering with ElvUI (thanks [Flamanis](https://github.com/Flamanis))
|
||||||
|
|
||||||
|
### v2.24-Release
|
||||||
|
- fix for WotLK v30402 (update libs)
|
||||||
|
- update DRList
|
||||||
|
- fix taint issue on first load up
|
||||||
|
|
||||||
|
### v2.23-Release
|
||||||
|
- fix for WotLK v30401 (update libs + layers + masks)
|
||||||
|
|
||||||
|
### v2.22-Release
|
||||||
|
- fixed unwanted committed changes to LibCustomGlow
|
||||||
|
|
||||||
|
### v2.21-Release
|
||||||
|
- **Cooldowns**
|
||||||
|
- glows minor fix again...
|
||||||
|
- more tracking
|
||||||
|
- **Pets**
|
||||||
|
- death detection improved
|
||||||
|
- detection improved
|
||||||
|
|
||||||
|
### v2.20-Release
|
||||||
|
- **Cooldowns**
|
||||||
|
- glow changed to PixelGlow
|
||||||
|
- glow color configurable
|
||||||
|
- improved tracking
|
||||||
|
- feign death cd tracking
|
||||||
|
- fixed Elemental Mastery and Presence of Mind tracking
|
||||||
|
- **Auras**
|
||||||
|
- improved **Aura** tracking
|
||||||
|
- stealthed unit **Aura** tracking improved
|
||||||
|
- fixed Berserking Wrath
|
||||||
|
- **Totemplates**
|
||||||
|
- ElvUI fix
|
||||||
|
- fix ManaSpringTotem
|
||||||
|
- fix Paladin **SpecDetection**
|
||||||
|
- fix DRList conflict with Diminish
|
||||||
|
- minor bugfixes/improvements
|
||||||
|
|
||||||
### v2.20-Beta
|
### v2.20-Beta
|
||||||
- **Wrath** & **BCC** support
|
- **Wrath** & **BCC** support
|
||||||
- different auras/DRs/Cooldowns/Buffs per expansion
|
- different auras/DRs/Cooldowns/Buffs per expansion
|
||||||
|
81
Util.lua
81
Util.lua
@ -1,6 +1,9 @@
|
|||||||
local pairs, ipairs = pairs, ipairs
|
local pairs, ipairs = pairs, ipairs
|
||||||
|
local select = select
|
||||||
|
local type = type
|
||||||
local floor = math.floor
|
local floor = math.floor
|
||||||
local str_find, str_gsub, str_sub, tinsert = string.find, string.gsub, string.sub, table.insert
|
local str_find, str_gsub, str_sub, str_format = string.find, string.gsub, string.sub, string.format
|
||||||
|
local tinsert = table.insert
|
||||||
local Gladdy = LibStub("Gladdy")
|
local Gladdy = LibStub("Gladdy")
|
||||||
local L = Gladdy.L
|
local L = Gladdy.L
|
||||||
local AuraUtil = AuraUtil
|
local AuraUtil = AuraUtil
|
||||||
@ -179,4 +182,80 @@ function Gladdy:GetArenaUnit(unitCaster, unify)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function Gladdy:ShallowCopy(table)
|
||||||
|
local copy
|
||||||
|
if type(table) == 'table' then
|
||||||
|
copy = {}
|
||||||
|
for k,v in pairs(table) do
|
||||||
|
copy[k] = v
|
||||||
|
end
|
||||||
|
else -- number, string, boolean, etc
|
||||||
|
copy = table
|
||||||
|
end
|
||||||
|
return copy
|
||||||
|
end
|
||||||
|
|
||||||
|
function Gladdy:DeepCopy(table)
|
||||||
|
local copy
|
||||||
|
if type(table) == 'table' then
|
||||||
|
copy = {}
|
||||||
|
for k,v in pairs(table) do
|
||||||
|
if type(v) == 'table' then
|
||||||
|
copy[k] = self:DeepCopy(v)
|
||||||
|
else -- number, string, boolean, etc
|
||||||
|
copy[k] = v
|
||||||
|
end
|
||||||
|
end
|
||||||
|
else -- number, string, boolean, etc
|
||||||
|
copy = table
|
||||||
|
end
|
||||||
|
return copy
|
||||||
|
end
|
||||||
|
|
||||||
|
function Gladdy:AddEntriesToTable(table, entries)
|
||||||
|
for k,v in pairs(entries) do
|
||||||
|
if not table[k] then
|
||||||
|
table[k] = v
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function Gladdy:GetExceptionSpellName(spellID)
|
||||||
|
for k,v in pairs(Gladdy.exceptionNames) do
|
||||||
|
if k == spellID and Gladdy:GetImportantAuras()[v] and Gladdy:GetImportantAuras()[v].altName then
|
||||||
|
return Gladdy:GetImportantAuras()[v].altName
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return select(1, GetSpellInfo(spellID))
|
||||||
|
end
|
||||||
|
|
||||||
|
local function toHex(color)
|
||||||
|
if not color or not color.r or not color.g or not color.b then
|
||||||
|
return "000000"
|
||||||
|
end
|
||||||
|
return str_format("%.2x%.2x%.2x", floor(color.r * 255), floor(color.g * 255), floor(color.b * 255))
|
||||||
|
end
|
||||||
|
function Gladdy:SetTextColor(text, color)
|
||||||
|
return "|cff" .. toHex(color) .. text or "" .. "|r"
|
||||||
|
end
|
||||||
|
|
||||||
|
function Gladdy:ColorAsArray(color)
|
||||||
|
return {color.r, color.g, color.b, color.a}
|
||||||
|
end
|
||||||
|
|
||||||
|
function Gladdy:Dump(table, space)
|
||||||
|
if type(table) ~= "table" then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
if not space then
|
||||||
|
space = ""
|
||||||
|
end
|
||||||
|
for k,v in pairs(table) do
|
||||||
|
Gladdy:Print(space .. k .. " - ", v)
|
||||||
|
if type(v) == "table" then
|
||||||
|
Gladdy:Dump(v, space .. " ")
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
Loading…
Reference in New Issue
Block a user