Module:Toolbar: Difference between revisions
From Zoophilia Wiki
Jump to navigationJump to search
meta>Mr. Stradivarius allow access to the p._main function from other modules, return the blank string if no arguments were specified, and switch indentation to tabs |
meta>Mr. Stradivarius reorder the functions, and add an option to remove the enclosing span tags |
||
Line 1: | Line 1: | ||
-- This module implements {{toolbar}}. | |||
local mArguments -- Lazily initialise [[Module:Arguments]] | |||
local mTableTools = require('Module:TableTools') | |||
local yesno = require('Module:Yesno') | |||
local p = {} | local p = {} | ||
local function | function p.main(frame) | ||
-- | mArguments = require('Module:Arguments') | ||
local args = mArguments.getArgs(frame) | |||
return p._main(args) | |||
end | |||
function p._main(args) | |||
local toolbarItems = p.makeToolbarItems(args) | |||
if not toolbarItems then | |||
-- Return the blank string if no arguments were specified, rather than | |||
-- returning empty brackets. | |||
return '' | |||
elseif yesno(args.span) == false then | |||
return string.format( | |||
'(%s)', | |||
toolbarItems | |||
) | |||
else | |||
return string.format( | |||
'<span class="plainlinks%s"%s>(%s)</span>', | |||
type(args.class) == 'string' and ' ' .. args.class or '', | |||
type(args.style) == 'string' and string.format(' style="%s"', args.style) or '', | |||
toolbarItems | |||
) | |||
end | end | ||
end | end | ||
function p.makeToolbarItems(args) | |||
local nums = | local nums = mTableTools.numKeys(args) | ||
local sep = (args.separator or 'pipe') .. '-separator' | local sep = (args.separator or 'pipe') .. '-separator' | ||
sep = mw.message.new(sep):plain() | sep = mw.message.new(sep):plain() | ||
local ret = {} | local ret = {} | ||
for i, v in ipairs(nums) do | for i, v in ipairs(nums) do | ||
ret[#ret + 1] = args[v] | |||
end | end | ||
if #ret > 0 then | if #ret > 0 then | ||
return table.concat(ret, sep) | return table.concat(ret, sep) | ||
else | else | ||
return nil | |||
end | end | ||
end | end | ||
return p | return p |
Revision as of 08:26, 5 April 2014
Documentation for this module may be created at Module:Toolbar/doc
-- This module implements {{toolbar}}.
local mArguments -- Lazily initialise [[Module:Arguments]]
local mTableTools = require('Module:TableTools')
local yesno = require('Module:Yesno')
local p = {}
function p.main(frame)
mArguments = require('Module:Arguments')
local args = mArguments.getArgs(frame)
return p._main(args)
end
function p._main(args)
local toolbarItems = p.makeToolbarItems(args)
if not toolbarItems then
-- Return the blank string if no arguments were specified, rather than
-- returning empty brackets.
return ''
elseif yesno(args.span) == false then
return string.format(
'(%s)',
toolbarItems
)
else
return string.format(
'<span class="plainlinks%s"%s>(%s)</span>',
type(args.class) == 'string' and ' ' .. args.class or '',
type(args.style) == 'string' and string.format(' style="%s"', args.style) or '',
toolbarItems
)
end
end
function p.makeToolbarItems(args)
local nums = mTableTools.numKeys(args)
local sep = (args.separator or 'pipe') .. '-separator'
sep = mw.message.new(sep):plain()
local ret = {}
for i, v in ipairs(nums) do
ret[#ret + 1] = args[v]
end
if #ret > 0 then
return table.concat(ret, sep)
else
return nil
end
end
return p