(deasbaireachd⧼tpt-languages-separator⧽deasaich⧼tpt-languages-separator⧽eachdraidh⧼tpt-languages-separator⧽ceanglaichean⧼tpt-languages-separator⧽doc⧼tpt-languages-separator⧽bogsa-gainmhich⧼tpt-languages-separator⧽cùisean deuchainn)

This module displays an icon depending on the code it is given. It implements [{{Icon}}.

Ùsaid - Usage

Ùsaid bho uiciteacsa - Usage from wikitext

From wikitext this module should be used via [{{Icon}}. Please see the template page for documentation.

Ùsaid bho Lua - Usage from Lua

To use this module from another Lua module, first load it:

local mIcon = require('Mòideal:Icon')

Then you can make icons with the _main function.

mIcon._main(args)

The args variable is a table of arguments. This corresponds to the parameters accepted by [{{Icon}} - please see the template page for parameter documentation.

Dàta - Data

The icon data is stored at Mòideal:Icon/data. See the instructions there for how to add and remove icons.



-- This module implements [[Teamplaid:Icon]].

local data = mw.loadData('Mòideal:Icon/data')

local p = {}

function p._main(args)
	local code = args.class or args[1]
	local iconData
	if code then
		code = code:match('^%s*(.-)%s*$'):lower() -- trim whitespace and put in lower case
		iconData = data[code]
	end
	if not iconData then
		iconData = data._DEFAULT
	end
	return string.format(
		'[[File:%s%s|%s|link=]]',
		iconData.image,
		iconData.tooltip and '|' .. iconData.tooltip or '',
		args.size or '16x16px'
	)
end

function p.main(frame)
	local args = {}
	for k, v in pairs(frame:getParent().args) do
		args[k] = v
	end
	return p._main(args)
end

return p