Module:Error: Difference between revisions

From TEPwiki, Urth's Encyclopedia
Jump to navigation Jump to search
Content added Content deleted
(make it behave like Template:Error)
m (19 revisions imported: infobox)
 
(17 intermediate revisions by 3 users not shown)
Line 1: Line 1:
-- This module implements {{error}}
-- This module implements {{error}}.


local p = {}
local p = {}

local HtmlBuilder = require('Module:HtmlBuilder')


local function _error(args)
local function _error(args)
local s = args.message or args[1] or error('no message specified', 2)
local tag = mw.ustring.lower(tostring(args.tag))
local tag = mw.ustring.lower(tostring(args.tag))


-- Work out what html tag we should use.
local t
if tag == 'p' or tag == 'span' or tag == 'div' then
if not (tag == 'p' or tag == 'span' or tag == 'div') then
t = tag
tag = 'strong'
else
t = 'strong'
end
end
local root = HtmlBuilder.create(t)


-- Generate the html.
root
return tostring(mw.html.create(tag)
.addClass('error')
.wikitext(tostring(s))
:addClass('error')
:wikitext(tostring(args.message or args[1] or error('no message specified', 2)))

)
return tostring(root)
end
end


function p.error(frame)
function p.error(frame)
local origArgs
local args
if frame == mw.getCurrentFrame() then
if type(frame.args) == 'table' then
-- We're being called via #invoke. If the invoking template passed any args, use
-- We're being called via #invoke. The args are passed through to the module
-- them. Otherwise, use the args that were passed into the template.
-- from the template page, so use the args that were passed into the template.
origArgs = frame:getParent().args
args = frame.args
for k, v in pairs(frame.args) do
origArgs = frame.args
break
end
else
else
-- We're being called from another module or from the debug console, so assume
-- We're being called from another module or from the debug console, so assume
-- the args are passed in directly.
-- the args are passed in directly.
origArgs = frame
args = frame
end
end
-- ParserFunctions considers the empty string to be false, so to preserve the previous
-- if the message parameter is present but blank, change it to nil so that Lua will
-- consider it false.
-- behavior of the template, change any empty arguments to nil, so Lua will consider
if args.message == "" then
-- them false too.
args.message = nil

local args = {}
for k, v in pairs(origArgs) do
if v ~= '' then
args[k] = v
end
end
end

local args = origArgs
return _error(args)
return _error(args)
end
end

Latest revision as of 20:40, 23 April 2019

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

-- This module implements {{error}}.

local p = {}

local function _error(args)
    local tag = mw.ustring.lower(tostring(args.tag))

    -- 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 so that Lua will
    -- consider it false.
    if args.message == "" then
        args.message = nil
    end
    return _error(args)
end

return p