Module:Miscellaneous
Overview
Module for implementing various templates in lua that are not big/complex enough to warrent their own module.
List of currently implemented templates
The above documentation is transcluded from Module:Miscellaneous/doc.
Editors can experiment in this module's sandbox and testcases pages.
Subpages of this module.
Editors can experiment in this module's sandbox and testcases pages.
Subpages of this module.
--[[
Module for implementing miscellaneous templates in lua.
Mostly exists here so we don't have hundred of module pages for templates that don't have a lot of code.
If a template requires a *lot* of coding consider moving it into it's own lua module.
]]--
local xtable = require('Module:Table')
local util = require('Module:Util')
local getArgs = require('Module:Arguments').getArgs
local m_item = require('Module:Item')
local p = {}
local g_frame, g_args
--
-- Template: GemLevelTable
--
function p.gem_level_table(frame)
g_args = getArgs(frame, {
parentFirst = true
})
if frame == nil or type(frame) == 'table' then
frame = mw.getCurrentFrame()
end
g_args.width = g_args.width or 'auto'
local out = {}
out[#out+1] = '{| class="wikitable GemLevelTable" '
out[#out+1] = 'style="width: '
out[#out+1] = g_args.width
out[#out+1] = '; text-align: center"\n'
out[#out+1] = '! Level\n'
abbr = mw.html.create('abbr')
abbr
:attr('title', '[[Image:Level_up_icon_small.png|link=|Lvl.]]')
:attr('class', 'nounderline')
:wikitext('Required Level')
:done()
out[#out+1] = '!' .. tostring(abbr) .. '\n'
local attributes = {Str = 'Strength', Dex = 'Dexterity', Int = 'Intelligence'}
for attr, attr_full in pairs(attributes) do
if g_args[string.lower(attr)] ~= nil then
abbr = mw.html.create('abbr')
abbr
:attr('title', '[[Image:' .. attr_full .. 'Icon_small.png|link=|' .. attr .. '.]]')
:attr('class', 'nounderline')
:wikitext('Required ' .. attr_full)
:done()
out[#out+1] = '!' .. tostring(abbr) .. '\n'
end
end
-- original had cost, reserve, duration, radius, unneeded I believe
i = 0
-- increase if necessary
while i < 25 do
local header = g_args['c' .. i]
if header ~= nil then
out[#out+1] = '! ' .. header .. '\n'
end
i = i + 1
end
abbr = mw.html.create('abbr')
abbr
:attr('title', 'Experience Needed to Level Up')
:wikitext('Exp.')
:done()
out[#out+1] = '!' .. tostring(abbr) .. '\n'
abbr = mw.html.create('abbr')
abbr
:attr('title', 'Total Experience Needed')
:wikitext('Total Exp.')
:done()
out[#out+1] = '!' .. tostring(abbr) .. '\n'
return table.concat(out)
end
--
-- Template: ItemFilterList
--
function p.filter_list(frame)
g_args = getArgs(frame, {
parentFirst = true
})
if frame == nil or type(frame) == 'table' then
frame = mw.getCurrentFrame()
end
g_frame = frame
g_args.type = g_args.type or ''
tbl = mw.html.create('table')
tbl
:attr('class', 'wikitable sortable')
tblrow = tbl:tag('tr')
:tag('th')
:attr('rowspan', 2)
:wikitext('Name')
:done()
:tag('th')
:attr('rowspan', 2)
:wikitext('Author')
:done()
:tag('th')
:attr('rowspan', 2)
:wikitext('Release')
:done()
:tag('th')
:attr('colspan', 9)
:wikitext('Ingame Features')
:done()
:tag('th')
:attr('colspan', 1)
:wikitext('Other Features')
:done()
:tag('th')
:attr('colspan', 2)
:wikitext('Filtration Support')
:done()
if g_args.type == 'specialized' then
tblrow:tag('th')
:attr('rowspan', 2)
:wikitext('Description')
:done()
end
tblrow = tbl:tag('tr')
:tag('th')
:wikitext('Colours')
:done()
:tag('th')
:wikitext('Borders')
:done()
:tag('th')
:wikitext('Font<br>Size')
:done()
:tag('th')
:wikitext('Background')
:done()
:tag('th')
:wikitext('Item<br>Hiding')
:done()
:tag('th')
:wikitext('Leveling')
:done()
:tag('th')
:wikitext('Endgame')
:done()
:tag('th')
:wikitext('Vendor<br>recipes')
:done()
:tag('th')
:wikitext('Crafting')
:done()
-- Other Features
:tag('th')
:wikitext('Customizable')
:done()
-- Filtration
:tag('th')
:wikitext('General')
:done()
:tag('th')
:wikitext('Themes')
:done()
:done()
:wikitext(g_args.rows)
--return tostring(tbl) .. frame:extensionTag{ name = 'references', content = '', args = {group='note'}}
return tostring(tbl)
end
--
-- Template: ItemFilterListRow
--
local filter_list_required_args = xtable:new({'name', 'release_link', 'author', 'release', 'colour', 'border', 'font_size', 'background', 'item_hiding', 'leveling', 'endgame', 'vendor_recipes', 'crafting'})
local filter_list_range_args = xtable:new({'colour', 'border', 'font_size', 'background', 'item_hiding', 'leveling', 'endgame', 'vendor_recipes', 'crafting'})
local filter_list_range_values = xtable:new({'no', 'minor', 'partial', 'major', 'yes'})
local filter_list_yes_no_args = xtable:new({'customization', 'filtration_general', 'filtration_themes'})
local filter_list_yes_no = xtable:new({'no', 'partial', 'yes', 'unknown'})
-- Test: =p.filter_list{rows=p.filter_list_row{name='a', release_link='http://google.de', author='Mario', author_contact='No idea', direct_link='http://google.de', colour='yes', border='yes', font_size='no', item_hiding='yes', leveling=0, endgame=4, vendor_recipes='partial', crafting='no', release='2015'}}
-- =p.filter_list{type='specialized',rows=p.filter_list_row{type='specialized', name='a', release_link='http://google.de', author='Mario', author_contact='No idea', direct_link='http://google.de', colour='yes',colour_note="test", border='yes', font_size='no', background='no', item_hiding='yes', leveling=0, endgame=4, vendor_recipes='partial', crafting='no', release='2015', description='test'}}
function p.filter_list_row(frame)
g_args = getArgs(frame, {
parentFirst = true
})
if frame == nil or type(frame) == 'table' then
frame = mw.getCurrentFrame()
end
g_frame = frame
-- Checking args
for _, arg in ipairs(filter_list_required_args) do
if g_args[arg] == nil then
error('Required argument ' .. arg .. ' is missing')
end
end
g_args.filtration_general = g_args.filtration_general or 'unknown'
g_args.filtration_themes = g_args.filtration_themes or 'unknown'
g_args.customization = g_args.customization or 'unknown'
g_args.descriptipon = g_args.description or '<br>'
g_args.type = g_args.type or ''
-- Checking & formatting args
for _, arg in ipairs(filter_list_range_args) do
local val = g_args[arg]
local index = filter_list_range_values:index(val)
if index then
g_args[arg] = index
else
index = util.cast.number(val)
if index ~= nil and index >= 0 and index < filter_list_range_values:size() then
-- Lua starts counting at 1
g_args[arg] = index+1
else
error('Argument ' .. arg .. ' requires one of the following arguments: ' .. table.concat(filter_list_range_values, ' '))
end
end
end
for _, arg in ipairs(filter_list_yes_no_args) do
local val = g_args[arg]
if not filter_list_yes_no:contains(val) then
error('Argument ' .. arg .. ' requires one of the following arguments: ' .. table.concat(filter_list_yes_no, ' '))
end
end
-- Output
tblrow = mw.html.create('tr')
tblrow
:tag('td')
:wikitext('[' .. g_args.release_link .. ' ' .. g_args.name .. ']')
:done()
:tag('td')
:wikitext(g_args.author)
:done()
:tag('td')
:wikitext(g_args.release)
:done()
-- Basic Features
for _, arg in ipairs(filter_list_range_args) do
local index = g_args[arg]
local text = filter_list_range_values[index] or ''
local note = g_args[arg .. '_note']
tblrow
:tag('td')
:attr('class', 'table-cell-coloured table-cell-' .. text )
:attr('data-sort-value', index)
:wikitext(filter_list_get_arg(arg))
:done()
end
-- Other Features
for _, arg in ipairs(filter_list_yes_no_args) do
local val = g_args[arg]
tblrow
:tag('td')
:attr('class', 'table-cell-coloured table-cell-' .. val)
:attr('data-sort-value', '' .. filter_list_yes_no:index(val))
:wikitext(filter_list_get_arg(arg))
:done()
end
if g_args.type == 'specialized' then
tblrow
:tag('td')
:wikitext(filter_list_get_arg('description'))
:done()
end
return tostring(tblrow)
end
function filter_list_get_arg(arg)
--[[
Return a formatted table cell for the given argument
]]--
local val = g_args[arg]
if type(val) == 'number' then
val = filter_list_range_values[val]
end
if g_args[arg .. '_note'] ~= nil then
abbr = mw.html.create('abbr')
abbr
:attr('title', g_args[arg .. '_note'])
:wikitext(val)
:done()
return tostring(abbr)
else
return val
end
end
return p