Module:LocLine
The LocLine templates are used to list a monster's locations. Three templates are used to form the locations table:
- {{LocTableHead}}- Contains table headers for the top of the locations table
- {{LocLine}}- Template for all of the individual location lines
- {{LocTableBottom}}- Contains table footers for the bottom of the locations table
Usage
{{LocTableHead}}
{{LocLine
|name        = <!-- (Optional) Name of monster, defaults to article's title -->
|location         = <!-- Location -->
|levels      = <!-- Level(s) of the monster spawns at this location -->
|members     = <!-- (Optional) "yes" if location is members-only, defaults to "no" -->
|mapID       = <!-- (Optional) The interactive map ID; see Template:Map for more info -->
|plane       = <!-- (Optional) The interactive map plane; see Template:Map for more info -->
|(coordN)      <!-- One or more coordinates given as unnamed parameters; see Template:Map for more info -->
|mtype       = <!-- (Semi-required) Tells the map what style of map the coordinates will show up as (pin, polygon, square, circle) -->
}}
{{LocTableBottom}}
Unfilled location lines for quick copy-paste
{{LocTableHead}}
{{LocLine
|location = 
|levels = 
|members = 
|mapID = 
|plane = 
|mtype = 
}}
{{LocTableBottom}}
Parameter details
name
Optional. Name of the monster/NPC. Defaults to the title of the page on which the template is placed. Used as a title in the tooltips that appear when clicking on the pins of the interactive map.
location
Text, typically an article link, used to name a given location row.
levels
The level or levels (typically given as a comma-separated list of numbers and/or ranges) of the monster spawns at the given location.
members
Optional. A "yes" or "no" value indicating whether or not the given location is members-only. Defaults to "no".
mapID
Optional. The interactive map ID. See {{Map}} for more info.
plane
Optional. The inteactive map plane. See {{Map}} for more info.
mtype
Semi-required. Type of map design with coordinates. (pin, circle, square, polygon)
Unnamed parameters
One or more coordinates given as unnamed parameters. See {{Map}} for more info. Note that both the (x,y) form (e.g. |1234,4567) and the key-value pair form (e.g. |desc:A description for the pin,x:1234,y:4567) are accepted.
Note: When using the key-value pair form, passing an npcid value without specifying a pin description (via a desc value) will generate a pin description in the form of: NPC ID: 1234. This mirrors the behaviour used by {{Monster map}} and {{NPC map}}.
local p = {}
local editBtn = '<small>' .. require('Module:Edit button')() .. '</small>'
local yesno = require('Module:Yesno')
local isEmpty = require('Module:Paramtest').is_empty
local hc = require('Module:Paramtest').has_content
local buildMap = require('Module:Map').buildMap
local membscol = {
	[true] = '[[File:Member icon.png|link=Members]]',
	[false] = '[[File:Free-to-play icon.png|link=Free-to-play]]',
}
function p.main(frame)
	local args = frame:getParent().args
	local templateArgs = frame.args
	-- Copy args into new table to avoid custom scribunto iteration behavior on args
	local mapArgs = {}
	for k,v in pairs(args) do
    	mapArgs[k] = v
	end
	
	if not hc(mapArgs.mtype) then mapArgs.mtype = 'pin' end
	mapArgs.icon = templateArgs.icon
	mapArgs.ptype = templateArgs.ptype
	mapArgs.type = 'maplink'
	local loc = args.location or '? ' .. editBtn
	if (isEmpty(loc)) then loc = '? ' .. editBtn end
	local membs = membscol[yesno(args.members ~= nil and args.members or "no")]
	
	local spawns = args.spawns
	if spawns == nil then
		local i = 1
		while args[i] do i = i + 1 end -- Counts up the amount of spawns
		spawns = i - 1
	end
	if spawns == 0 then spawns = '? ' .. editBtn end
	
	local mapping = buildMap(mapArgs)
	
	-- build table row to return
	local locationRow = mw.html.create('tr')
	locationRow:tag('td'):wikitext(loc):done()
	if templateArgs.ptype == 'monster' then
		local levels = args.levels
		if (isEmpty(levels)) then levels = '? ' .. editBtn end
		locationRow:tag('td'):addClass(levels == 'N/A' and 'table-na' or ''):wikitext(levels):done()
	end
	locationRow:tag('td'):wikitext(membs):done()
	locationRow:tag('td'):wikitext(spawns):done()
	locationRow:tag('td'):wikitext(mapping):done()
	
	return tostring(locationRow)
end
return p