Module:Statname

-- local getArgs = require('Module:Arguments').getArgs local loader = require('Module:Loader')

local string, yesno, color = loader.require('String', 'Yesno', 'Color')

local aliases, statData = loader.loadData('Statname/Aliases', 'Statname/Data')

local p = {}

function p._getstatdata(statname, noerror) if not noerror then assertTrue(type(statname) == 'string', '`statname` must be a string') end local stat = string.trim(tostring(statname):lower):gsub('_', ' ') local dt = statData[aliases[stat] or stat] if not dt then for k, v in pairs(statData) do			if stat == v.name:lower or stat == v.shortcode:lower or stat == v.nameShort:lower or stat == v.nameSuperShort:lower then dt = v				break end end end if not noerror then assertTrue(dt, 'bad argument #1 to \'_getstatdata\' (Unknown stat %q)', 2, stat) end return dt end

- -- Template: Statname -- -- Makes a formatted stat with an image - function p.stat(frame) local args = getArgs(frame) local short = args[3] or args['short'] return p._stat({		stat = args[1],		valBefore = args[2],		isShort = yesno(short),		isSuperShort = short == 'ss',		isCram = args.cram,		icononly = args.icononly,	}) end

- -- Template: StatnameShort -- -- Makes a formatted short stat with an image - function p._statShort(frame) local args = getArgs(frame) return p._stat({		stat = args[1],		valBefore = args[2],		isShort = true,		isSuperShort = false,		isCram = args.cram,		icononly = args.icononly,	}) end

- -- Template: StatnameSuperShort -- -- Makes a formatted super short stat with an image - function p._statSuperShort(frame) local args = getArgs(frame) return p._stat({		stat = args[1],		valBefore = args[2],		isShort = true,		isSuperShort = true,		isCram = args.cram,		icononly = args.icononly,	}) end

- -- function: stat(stat, valBefore, isShort, isSuperShort) -- -- Makes a formatted stat with an image - function p._stat(...) local _stat, valBefore, isShort, isSuperShort, isCram, icononly if type(({...})[1]) == 'table' then local u = ({...})[1] _stat, valBefore, isShort, isSuperShort, isCram, icononly = u.stat or u[1], u.valBefore, u.isShort, u.isSuperShort, u.isCram, u.icononly else _stat, valBefore, isShort, isSuperShort, isCram, icononly = ... end assertTrue(_stat and (_stat.lower == string.lower), '`stat` must be a string', 2) local tValBefore, stat = _stat:lower:match('^([%-%+]?[%d%.]+%%?)%s*(.+)$') if not stat then stat = _stat else valBefore = tValBefore end stat = p._getstatdata(stat) assertTrue(stat, 'Invalid stat name %q', 2, _stat) local text = stat.character .. (icononly and '' or ' ' .. (isSuperShort and stat.nameSuperShort or (isShort and stat.nameShort or stat.name))) return string.wrapHtml{ {			valBefore and color.colorText(stat.color, valBefore) .. ' ' or '', stat.prefix and string.makeLink(stat.prefixName, color.colorText(stat.prefixColor, isSuperShort and stat.prefixNameSuperShort or isShort and stat.prefixNameShort or stat.prefixName)) .. ' ' or '', string.makeLink(				stat.link or stat.name,				color.colorText(stat.color, text)			), },		' ', {			class = 'hsw-gamefont ' .. (isCram and ' cram' or '') }	} end

- -- function: isStatAlias(s: string) -- -- Checks if a string is a valid stat name or alias. - function p.isStatAlias(s) return not not aliases[s] end

-- For backwards compatabillity p.getStatNameSuperShort = p._statSuperShort p.getStatNameShort = p._statShort p.getStatName = p.stat p._getStatName = p._stat

return p