Module:Utils: Difference between revisions
From Halopedia, the Halo wiki
No edit summary |
mNo edit summary |
||
(14 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
local utils = {} | local utils = {} | ||
function utils.strip( str ) | |||
return mw.ustring.gsub(str, '^%s*(.-)%s*$', '%1') | |||
end | |||
function utils.empty( val ) | |||
return val == nil or val == '' | |||
end | |||
function utils.defaultIfEmpty( val, default ) | function utils.defaultIfEmpty( val, default ) | ||
Line 16: | Line 24: | ||
return nil | return nil | ||
end | end | ||
end | |||
function generateErrorWikitext( message, type, category, template ) | |||
local wikitext = [[''']] | |||
.. string.upper( type ) | |||
.. [[:''' ]] | |||
.. message | |||
if template ~= nil then | |||
wikitext = wikitext .. ' (Template: [[Template:' | |||
.. template | |||
.. '|' | |||
.. template | |||
.. ']])' | |||
end | |||
local categorylink = '[[Category:' .. category .. ']]' | |||
return wikitext, categorylink | |||
end | end | ||
Line 25: | Line 51: | ||
local template = utils.defaultIfEmpty( select( 4, ... ), nil ) | local template = utils.defaultIfEmpty( select( 4, ... ), nil ) | ||
-- | -- Generate data | ||
local wikitext, categorylink = generateErrorWikitext( message, etype .. ' error', category, template ) | |||
-- Add custom styling | |||
wikitext = [[<span class="error halopedia-template-error" style="color: red;">]] .. wikitext .. [[</span>]] | |||
-- Add a warning to the edit preview | -- Add a warning to the edit preview | ||
mw.addWarning( wikitext ) | |||
-- Create and return the text to display on the page itself | -- Create and return the text to display on the page itself | ||
return | return wikitext .. ' ' .. categorylink | ||
end | end | ||
function utils.warning( ... ) | function utils.warning( ... ) | ||
-- Collect necessary information to display | -- Collect necessary information to display error | ||
local message = tostring( utils.defaultIfEmpty( select( 1, ... ), 'This template issued a warning. Are the parameters all correct?' ) ) | local message = tostring( utils.defaultIfEmpty( select( 1, ... ), 'This template issued a warning. Are the parameters all correct?' ) ) | ||
local wtype = tostring( utils.defaultIfEmpty( select( 2, ... ), 'Template' ) ) | local wtype = tostring( utils.defaultIfEmpty( select( 2, ... ), 'Template' ) ) | ||
Line 52: | Line 71: | ||
local template = utils.defaultIfEmpty( select( 4, ... ), nil ) | local template = utils.defaultIfEmpty( select( 4, ... ), nil ) | ||
-- | -- Generate data | ||
local wikitext, categorylink = generateErrorWikitext( message, wtype .. ' warning', category, template ) | |||
-- Add | -- Add custom styling | ||
wikitext = [[<span class="warning halopedia-template-warning" style="color: orange;">]] .. wikitext .. [[</span>]] | |||
-- Add the warning to the edit preview | |||
mw.addWarning( wikitext ) | |||
-- Create and return the text to add to the page. In this case, we only add | -- Create and return the text to add to the page. In this case, we only add | ||
-- the category - no message, as warnings should be silent to the reader | -- the category - no message, as warnings should be silent to the reader | ||
return | return categorylink | ||
end | end | ||
return utils | return utils |
Latest revision as of 13:55, December 27, 2021
Documentation for this module may be created at ModuleDoc:Utils
local utils = {}
function utils.strip( str )
return mw.ustring.gsub(str, '^%s*(.-)%s*$', '%1')
end
function utils.empty( val )
return val == nil or val == ''
end
function utils.defaultIfEmpty( val, default )
if val == nil or val == '' then
return default
else
return val
end
end
function utils.loadDataIfExists( name )
local success, data = pcall( mw.loadData, name )
if success then
return data
else
return nil
end
end
function generateErrorWikitext( message, type, category, template )
local wikitext = [[''']]
.. string.upper( type )
.. [[:''' ]]
.. message
if template ~= nil then
wikitext = wikitext .. ' (Template: [[Template:'
.. template
.. '|'
.. template
.. ']])'
end
local categorylink = '[[Category:' .. category .. ']]'
return wikitext, categorylink
end
function utils.error( ... )
-- Collect necessary information to display error
local message = tostring( utils.defaultIfEmpty( select( 1, ... ), 'There was an error with a template. Are the parameters all correct?' ) )
local etype = tostring( utils.defaultIfEmpty( select( 2, ... ), 'Template' ) )
local category = tostring( utils.defaultIfEmpty( select( 3, ... ), 'Pages containing template errors' ) )
local template = utils.defaultIfEmpty( select( 4, ... ), nil )
-- Generate data
local wikitext, categorylink = generateErrorWikitext( message, etype .. ' error', category, template )
-- Add custom styling
wikitext = [[<span class="error halopedia-template-error" style="color: red;">]] .. wikitext .. [[</span>]]
-- Add a warning to the edit preview
mw.addWarning( wikitext )
-- Create and return the text to display on the page itself
return wikitext .. ' ' .. categorylink
end
function utils.warning( ... )
-- Collect necessary information to display error
local message = tostring( utils.defaultIfEmpty( select( 1, ... ), 'This template issued a warning. Are the parameters all correct?' ) )
local wtype = tostring( utils.defaultIfEmpty( select( 2, ... ), 'Template' ) )
local category = tostring( utils.defaultIfEmpty( select( 3, ... ), 'Pages containing template warnings' ) )
local template = utils.defaultIfEmpty( select( 4, ... ), nil )
-- Generate data
local wikitext, categorylink = generateErrorWikitext( message, wtype .. ' warning', category, template )
-- Add custom styling
wikitext = [[<span class="warning halopedia-template-warning" style="color: orange;">]] .. wikitext .. [[</span>]]
-- Add the warning to the edit preview
mw.addWarning( wikitext )
-- Create and return the text to add to the page. In this case, we only add
-- the category - no message, as warnings should be silent to the reader
return categorylink
end
return utils