Module:Error: Difference between revisions

From Ekatra Foundation
Jump to navigation Jump to search
m (1 revision imported: Importing Custome Rule Template)
enws>CalendulaAsteraceae
(improve default value of tag)
Line 1: Line 1:
-- This module implements {{error}}.
local p = {}
local p = {}


local function _error(args)
local function _error(args)
    local tag = mw.ustring.lower(tostring(args.tag))
local tag = mw.ustring.lower(tostring(args.tag or 'strong'))
 
    -- Work out what html tag we should use.
-- Work out what html tag we should use.
    if not (tag == 'p' or tag == 'span' or tag == 'div') then
if not (tag == 'p' or tag == 'span' or tag == 'div') then
        tag = 'strong'
tag = 'strong'
    end
end
 
    -- Generate the html.
-- Generate the html.
    return tostring(mw.html.create(tag)
return tostring(mw.html.create(tag)
        :addClass('error')
:addClass('error')
        :wikitext(tostring(args.message or args[1] or error('no message specified', 2)))
:wikitext(tostring(args.message or args[1] or error('no message specified', 2)))
    )
)
end
end


function p.error(frame)
function p.error(frame)
    local args
local args
    if type(frame.args) == 'table' then
if type(frame.args) == 'table' then
        -- We're being called via #invoke. The args are passed through to the module
--[=[
        -- from the template page, so use the args that were passed into the template.
We're being called via #invoke.
        args = frame.args
The args are passed through to the module from the template page,
    else
so use the args that were passed into the template.
        -- We're being called from another module or from the debug console, so assume
]=]
        -- the args are passed in directly.
args = frame.args
        args = frame
else
    end
--[=[
    -- if the message parameter is present but blank, change it to nil so that Lua will
We're being called from another module or from the debug console,
    -- consider it false.
so assume the args are passed in directly.
    if args.message == "" then
]=]
        args.message = nil
args = frame
    end
end
    return _error(args)
--[=[
If the message parameter is present but blank, change it to nil.
]=]
if args.message == '' then
args.message = nil
end
return _error(args)
end
end


return p
return p

Revision as of 09:04, 19 January 2025

Documentation for this module may be created at Module:Error/doc

local p = {}

local function _error(args)
	local tag = mw.ustring.lower(tostring(args.tag or 'strong'))
	
	-- Work out what html tag we should use.
	if not (tag == 'p' or tag == 'span' or tag == 'div') then
		tag = 'strong'
	end
	
	-- Generate the html.
	return tostring(mw.html.create(tag)
		:addClass('error')
		:wikitext(tostring(args.message or args[1] or error('no message specified', 2)))
	)
end

function p.error(frame)
	local args
	if type(frame.args) == 'table' then
		--[=[
			We're being called via #invoke.
			The args are passed through to the module from the template page,
			so use the args that were passed into the template.
		]=]
		args = frame.args
	else
		--[=[
			We're being called from another module or from the debug console,
			so assume the args are passed in directly.
		]=]
		args = frame
	end
	--[=[
		If the message parameter is present but blank, change it to nil.
	]=]
	if args.message == '' then
		args.message = nil
	end
	return _error(args)
end

return p