Module:Error: Difference between revisions
From All Skies Encyclopaedia
imported>Mr. Stradivarius (more comments) |
imported>Materialscientist m (Changed protection level for "Module:Error": Highly visible template ([Edit=Require template editor access] (indefinite) [Move=Require template editor access] (indefinite))) |
||
(14 intermediate revisions by 2 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. |
-- Work out what html tag we should use. |
||
if not (tag == 'p' or tag == 'span' or tag == 'div') then |
|||
local t |
|||
tag = 'strong' |
|||
⚫ | |||
⚫ | |||
t = 'strong' |
|||
end |
end |
||
local root = HtmlBuilder.create(t) |
|||
-- Generate the html |
-- Generate the html. |
||
⚫ | |||
root |
|||
:addClass('error') |
|||
:wikitext(tostring(args.message or args[1] or error('no message specified', 2))) |
|||
⚫ | |||
⚫ | |||
end |
end |
||
function p.error(frame) |
function p.error(frame) |
||
local |
local args |
||
if frame == |
if type(frame.args) == 'table' then |
||
-- We're being called via #invoke. |
-- 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 |
|||
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. |
||
args = frame |
|||
end |
end |
||
-- if the message parameter is present but blank, change it to nil so that Lua will |
|||
⚫ | |||
-- behavior of the template, change any empty arguments to nil, so Lua will consider |
|||
if args.message == "" then |
|||
⚫ | |||
⚫ | |||
local args = {} |
|||
for k, v in pairs(origArgs) do |
|||
if mw.ustring.match(v, '%S') then |
|||
args[k] = v |
|||
end |
|||
end |
end |
||
local args = origArgs |
|||
return _error(args) |
return _error(args) |
||
end |
end |
Latest revision as of 11:11, 21 November 2016
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