Module:Anchor: Difference between revisions

From The Midnight Wiki
(still accept {{{anchor}}}, used e.g. on Commons:European Science Photo Competition 2015/Winners)
 
(Add class per edit request)
Line 10: Line 10:
-- and pass them to p._main.
-- and pass them to p._main.
local args = getArgs(frame)
local args = getArgs(frame)
args[1] = args[1] or args.anchor
local argArray = tableTools.compressSparseArray(args)
local argArray = tableTools.compressSparseArray(args)
return p._main(unpack(argArray))
return p._main(unpack(argArray))
Line 20: Line 19:
local ret = {}
local ret = {}
for _, anchor in ipairs(anchors) do
for _, anchor in ipairs(anchors) do
ret[#ret + 1] = '<span id="' .. anchor .. '"></span>'
ret[#ret + 1] = '<span class="anchor" id="' .. anchor .. '"></span>'
end
end
return table.concat(ret)
return table.concat(ret)

Revision as of 17:32, 24 September 2020

Documentation for this module may be created at Module:Anchor/doc

-- This module implements {{anchor}}.

local getArgs = require('Module:Arguments').getArgs
local tableTools = require('Module:TableTools')

local p = {}

function p.main(frame)
	-- Get the positional arguments from #invoke, remove any nil values,
	-- and pass them to p._main.
	local args = getArgs(frame)
	local argArray = tableTools.compressSparseArray(args)
	return p._main(unpack(argArray))
end

function p._main(...)
	-- Generate the list of anchors.
	local anchors = {...}
	local ret = {}
	for _, anchor in ipairs(anchors) do
		ret[#ret + 1] = '<span class="anchor" id="' .. anchor .. '"></span>'
	end
	return table.concat(ret)
end

return p