Module:Top icons

From the RuneScape Wiki, the wiki for all things RuneScape
Jump to navigation Jump to search
Module documentation
This documentation is transcluded from Module:Top icons/doc. [edit] [history] [purge]
Module:Top icons's function main is invoked by Template:Indicators.
Module:Top icons is required by Module:Update.

Module used for Template:Indicators. Can also be imported into modules to display top icons.

This module is a helper module to be used by other modules; it may not designed to be invoked directly. See RuneScape:Lua/Helper modules for a full list and more information. For a full list of modules using this helper click here

FunctionTypeUse
_main( wiki1, wiki2, ... )string, string, ...Returns a string that adds top icons for the given wiki names. Values must be one of rs, rsc, meta or wp.
_main( wiki1 = pagename1, wiki2 = pagename2, ... )string, string, ...Returns a string that adds top icons for the given wiki names, linking to the specified page names. Wiki names must be one of rs, rsc, meta or wp.

--<nowiki>
local p = {}

local sites = {
	rsc = {
		format = 'The RuneScape Classic Wiki also has an article on: [[classicrsw:%s]]',
		params = { 'rsc', 'classic', 'c' },
		abbr = 'CS',
		title = 'The RuneScape Classic Wiki also has an article on %s.',
		},
	os = {
		format = 'The Old School RuneScape Wiki also has an article on: [[osrsw:%s]]',
		params = { 'oldschool', 'osrs', 'os', '2007', '07' },
		abbr = 'Old School',
		title = 'The Old School RuneScape Wiki also has an article on %s.',
		},
	wg = {
		format = '[[meta:%s]]',
		params = { 'meta', 'wg' },
		abbr = 'Weird Gloop',
		title = 'The Weird Gloop meta wiki also has an article on %s.',
		},
	wp = { 
		format = 'Wikipedia also has an article on: [[wikipedia:%s]]',
		params = { 'wikipedia', 'wp', 'w' },
		abbr = 'Wikipedia',
		title = 'Wikipedia also has an article on %s.',
		},
	}

local order = { 'os', 'rsc', 'wp', 'wg' }

local allparams = {}

function p.main(frame)
	local args = frame:getParent().args
	return p._main(args)
end

function p._main(args)
	local pagename = mw.title.getCurrentTitle().fullText
	local vals = {}
	-- create allparams
	for s,t in pairs(sites) do
		for _,v in ipairs(t.params) do
			allparams[v] = s
		end
	end
	
	-- loop named params
	for i,v in pairs(allparams) do
		if args[i] and not vals[v] then
			vals[v] = args[i]
		end
	end
	
	-- loop unnamed params
	local i = 1
	local v
	while args[i] do
		v = allparams[args[i]] 
		if v and not vals[v] then
			vals[v] = pagename
		end
		i = i + 1
	end
	
	local ret = mw.html.create('div')
	ret:addClass('rs-external-header-links'):css('display', 'none')
	for _,v in ipairs(order) do
		if vals[v] then
			local span = ret:tag('span')
			span:wikitext(string.format(sites[v].format, vals[v]))
				:addClass('rs-header-icon rs-header-icon-'..v)
				:attr({
						['data-title'] = string.format(sites[v].title, vals[v]),
						['data-site'] = v,
						['data-text'] = sites[v].abbr,
					})
		end
	end

	return tostring(ret)	
end

return p
--</nowiki>