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 )
-- Style data  
-- Generate  data  
etype = string.upper( etype )
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
if template == nil then
mw.addWarning( wikitext )
mw.addWarning( "'''" .. etype .. " ERROR:''' " .. message )
else
mw.addWarning( "'''" .. etype .. " ERROR:''' " .. message .. ' (Template name: "' .. tostring( template ) .. '")' )
end
-- Create and return the text to display on the page itself
-- Create and return the text to display on the page itself
return [[<span class="error halopedia-template-error" style="color: red;">''']]
return wikitext .. ' ' .. categorylink
.. etype
.. [[ ERROR:''' ]]
.. message
.. '</span> [[Category:'
.. category
.. ']]'
end
end


function utils.warning( ... )
function utils.warning( ... )
-- Collect necessary information to display 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 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 )
-- Style data  
-- Generate  data  
wtype = string.upper( wtype )
local wikitext, categorylink = generateErrorWikitext( message, wtype .. ' warning', category, template )
-- Add a warning to the edit preview
-- Add custom styling
if template == nil then
wikitext = [[<span class="warning halopedia-template-warning" style="color: orange;">]] .. wikitext .. [[</span>]]
mw.addWarning( "'''" .. wtype .. " WARNING:''' " .. message )
else
-- Add the warning to the edit preview
mw.addWarning( "'''" .. wtype .. " WARNING:''' " .. message .. ' (Template name: "' .. tostring( template ) .. '")' )
mw.addWarning( wikitext )
end
-- 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 '[[Category:' .. category .. ']]'
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