Module:Toolbar: Difference between revisions

From the Croc Wiki, the Croc encyclopedia
Jump to navigationJump to search
Content added Content deleted
(generate more natural html if class and style arguments are absent)
m (13 revisions imported)
 
(8 intermediate revisions by 4 users not shown)
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 args = {}


function p.main(frame)
-- Get the keys of the numerical arguments that are present.
mArguments = require('Module:Arguments')
local function getArgNums()
local nums = {}
local args = mArguments.getArgs(frame)
return p._main(args)
for k, v in pairs(args) do
if type(k) == 'number' then
table.insert(nums, k)
end
end
table.sort(nums)
return nums
end
end


local function makeToolbarItems()
function p._main(args)
local toolbarItems = p.makeToolbarItems(args)
-- Get numerical argument keys.
if not toolbarItems then
local nums = getArgNums()
-- Return the blank string if no arguments were specified, rather than
-- Get the separator text.
-- returning empty brackets.
local sep = (args.separator or 'pipe') .. '-separator'
return ''
sep = mw.message.new(sep):plain()
elseif yesno(args.span) == false then
return string.format(
-- Generate the toolbar items.
'(%s)',
local ret = ''
toolbarItems
for i, v in ipairs(nums) do
)
ret = ret .. args[v]
else
if nums[i + 1] then
return string.format(
ret = ret .. sep
'<span class="plainlinks%s"%s>(%s)</span>',
end
type(args.class) == 'string' and ' ' .. args.class or '',
end
type(args.style) == 'string' and string.format(' style="%s"', args.style) or '',
return ret
toolbarItems
)
end
end
end


local function makeToolbar()
function p.makeToolbarItems(args)
local class = (args.class and (' ' .. args.class)) or ''
local nums = mTableTools.numKeys(args)
local style = (args.style and (' style="' .. args.style .. '"')) or ''
local sep = (args.separator or 'pipe') .. '-separator'
sep = mw.message.new(sep):plain()
local ret = {}
local ret = '<span class="plainlinks' .. class .. '"' .. style .. '>'
for i, v in ipairs(nums) do
.. '(' .. makeToolbarItems() .. ')'
ret[#ret + 1] = mw.ustring.gsub(args[v], "%[%[::+(.-)%]%]", "[[:%1]]")
.. '</span>'
end
if #ret > 0 then
return ret
return table.concat(ret, sep)
else
return nil
end
end
end


function p.main(frame)
-- If called via #invoke, use the args passed into the invoking template.
-- Otherwise, for testing purposes, assume args are being passed directly in.
local origArgs
if frame == mw.getCurrentFrame() then
origArgs = frame:getParent().args
else
origArgs = frame
end
-- Strip whitespace and remove nil values
for k, v in pairs(origArgs) do
v = mw.text.trim(v)
if v ~= '' then
args[k] = v
end
end
return makeToolbar()
end
return p
return p

Latest revision as of 21:55, January 25, 2022

This module implements {{toolbar}}. Please see the template page for documentation.

See also


-- 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] = mw.ustring.gsub(args[v], "%[%[::+(.-)%]%]", "[[:%1]]")
	end
	if #ret > 0 then
		return table.concat(ret, sep)
	else
		return nil
	end
end

return p