Documentation for the core framework used in Zarillion's HandyNotes expansion plugins.
The base class for all nodes.
ns.node.Node({
label = 'Example Node',
icon = 'peg_yw',
note = 'This is a Note on the Example Node.'
})
ns.node.Node
has the following properties by default:
label
(string) (default: ‘UNKNOWN’)
minimap
(boolean) (default: true)
alpha
(float) (default: 1.0)
scale
(float) (default: 1.0)
icon
(string / int) (default: ‘default’)
group
(group) (default: ns.groups.MISC)
ns.node.Node
supports the following optional properties that affect a node’s tootlip:
sublabel
(string)
rlabel
(string)
questCount
(boolean)
rlabel
.location
(string)
note
(string)
requires
(Requirement / Requirement)
rewards
(Reward)
ns.node.Node
supports the following optional properties that affect a node’s visibility:
class
(string)
'DEATHKNIGHT'
'DEMONHUNTER'
'DRUID'
'EVOKER'
'HUNTER'
'MAGE'
'MONK'
'PALADIN'
'PRIEST'
'ROGUE'
'SHAMAN'
'WARLOCK'
'WARRIOR'
faction
(string)
'Alliance'
'Horde'
quest
(int / int[ ])
questID
in quest
have been completed.questAny
(boolean)(default: all)
questID
in quest
have been completed.questDeps
(int / int[ ])
questID
in questDeps
have been completed.ns.node.Node
supports the following optional properties that affect a node’s interaction:
fgroup
(string)
parent
(int)
mapID
to display this node on.parent
([ ])
parent
property also supports some basic Node properties.id
(int)(required)
mapID
to display this node on.note
(string)
pois
(POI)
pois
(POI)
map.nodes[58085381] = ns.node.Collectible({
id = 204693,
icon = 'peg_bl',
scale = 1.3
note = L['ponzo_note'],
rewards = {
DC.SetNote(DC.WindingSlitherdrake.HairyBrow, '55x'),
DC.SetNote(DC.WindingSlitherdrake.ClusterChinHorn, '55x'),
DC.SetNote(DC.WindingSlitherdrake.CurledNose, '55x'),
Pet({item = 205120, id = 3537, note = '85x'}), -- Thimblerig
Mount({item = 205209, id = 1736, note = '170x'}) -- Boulder Hauler
}
}) -- Ponzo <Barterer Extraordinaire>
ns.node.Collectible
supports the following properties:
id
(int)
npcID
for the NPC who offers the collectible. This will be used for the label
property.item
(int)
itemID
for the colectible. This will be used for the label
property.Please note that the label for ns.node.Collectible
can also come from the criteria for the first listed achievement in rewards
.
local MawIntro = Class('MawIntro', ns.node.Intro, {
quest = 62907, -- Eye of the Jailor activation
label = L['return_to_the_maw'],
note = L['maw_intro_note']
})
map.intro = MawIntro({
rewards = {
Quest({
id = {
62882, -- Setting the Ground Rules
60287 -- Rule 1: Have an Escape Plan
}
})
}
})
map.nodes[80306280] = map.intro
ns.node.Intro
has the following properties set by default:
scale
(float) (default: 3)
icon
(string / int) (default: ‘quest_ay’)
group
(group) (default: ns.groups.QUEST)
minimap
(boolean) (default: false)
ns.node.Intro
supports the following properties:
quest
(int)
questID
of the Intro Quest. This will be used for the label
property.map.nodes[78175317] = ns.node.Item({
id = 189418,
quest = 65327,
sublabel = '{spell:366368}',
icon = 132599,
group = ns.groups.PROTOFORM_SCHEMATICS
note = L['schematic_ambystan_darter_note']
}) -- Ambystan Darter
ns.node.Item
requires the following properties:
id
(int)
itemID
for the item. This will be used for the label
property.map.nodes[37164467] = ns.node.NPC({
id = 183962,
icon = 4254892,
requires = {
ns.requirement.GarrisonTalent(1902),
ns.requirement.Quest(65219)
},
note = L['olea_manu'],
rewards = {
Item({item = 187804, note = '25'}), -- Recipe: Empty Kettle of Stone Soup
Item({item = 187824, note = '25'}), -- Formula: Magically Regulated Automa Core
Item({item = 188793, quest = 65282, note = '150'}), -- Improved Cypher Analysis Tool
Item({item = 189986, quest = 65514, covenant = NIGHTFAE, note = '500'}), -- Armadillo Soul
Item({item = 189980, quest = 65510, covenant = NIGHTFAE, note = '1000'}), -- Brutosaur Soul
Toy({item = 190333, note = '100'}), -- Jiro Circle of Song
Pet({item = 191039, id = 3247, note = '500'}), -- Pocopoc Traveler
Item({item = 187781, note = '700'}) -- Olea Cache
}
}) -- Olea Manu
ns.node.NPC
requires the following properties:
id
(int)
npcID
for the NPC. This will be used for the label
property.map.nodes[13095369] = ns.node.PetBattle({
id = 200689,
rewards = {Achievement({id = 17541, criteria = 58574})} -- Global Swarming
}) -- Wildfire
ns.node.PetBattle
has the following properties set by default:
scale
(float) (default: 1.2)
icon
(string / int) (default: ‘paw_y’)
group
(group) (default: ns.groups.PETBATTLE)
ns.node.PetBattle
requires the following properties:
id
(int)
npcID
for the NPC who offers the pet battle. This will be used for the label
property.map.nodes[53486145] = Quest({
quest = 55743,
questDeps = 56117,
daily = true,
minimap = false,
scale = 1.8,
rewards = {
Achievement({id = 13708, criteria = {45772, 45775, 45776, 45777, 45778}}), -- Most Minis Wins
Item({item = 169848, weekly = 57134}) -- Azeroth Mini Pack: Bondo's Yard
}
})
ns.node.Quest
has the following properties set by default:
icon
(string / int) (default: ‘quest_ay’)
ns.node.Quest
supports the following properties:
id
(int)
questID
of the Quest. This will be used for the label
property.daily
(boolean)
icon
property, when it is true
the icon will set it to 'quest_ab'
.map.nodes[43947530] = ns.node.Rare({
id = 183516,
quest = 65580,
vignette = 4933,
note = L['the_engulfer_note'],
rlabel = ns.status.LightBlue('+10 ' .. L['rep']),
rewards = {
Achievement({id = 15391, criteria = 53050}), -- Adventurer of Zereth Mortis
Transmog({item = 189913, slot = L['cloth']}), -- Engulfer's Tightening Cinch
Transmog({item = 189921, slot = L['leather']}), -- Devourer's Insatiable Grips
Transmog({item = 190006, slot = L['1h_sword']}) -- Anima-Siphoning Sword
}
}) -- The Engulfer
ns.node.Rare
has the following properties set by default:
scale
(float) (default: 1.2)
icon
(string / int) (default: ‘skull_b’)
'skull_w'
when all rewards have been collected.group
(group) (default: ns.groups.RARE)
ns.node.Rare
requires the following properties:
id
(int)
npcID
for the rare. This will be used for the label
property.It is highly recommended that you add the quest
property to rares and use the hidden questID
used by Blizzard to track if a rare has been killed for the day.
quest
(int)
questID
used to track the daily kill.map.nodes[65804182] = ns.node.Treasure({
quest = 70600,
note = L['golden_dragon_goblet_note'],
requires = {
ns.requirement.Quest(72709), -- Funding a Treasure Hunt
ns.requirement.Quest(70409, '{item:198854}') -- Archeologist Artifact Notes
},
rewards = {
Achievement({id = 16297, criteria = 54698}), -- Treasures of The Waking Shores
Toy({item = 202019}) -- Golden Dragon Goblet
},
pois = {POI({77992943})}
}) -- Golden Dragon Goblet
ns.node.Treasure
has the following properties set by default:
scale
(float) (default: 1.3)
icon
(string / int) (default: ‘chest_gy’)
group
(group) (default: ns.groups.TREASURE)
It is highly recommended that you add the quest
property to rares and use the hidden questID
used by Blizzard to track if a treasure has been collected.
quest
(int)
questID
used to track a the collected treasure.Please note that by default the label for ns.node.Treasure
comes from the criteria for the first listed achievement in rewards
.