Changes

Jump to navigation Jump to search
595 bytes removed ,  20:51, 26 July 2018
m
Protected "Module:Message box": High-risk Lua module ([Edit=Allow only administrators] (indefinite) [Move=Allow only administrators] (indefinite))
Line 5: Line 5:  
require('Module:No globals')
 
require('Module:No globals')
 
local getArgs
 
local getArgs
 +
local categoryHandler = require('Module:Category handler')._main
 
local yesno = require('Module:Yesno')
 
local yesno = require('Module:Yesno')
    
-- Get a language object for formatDate and ucfirst.
 
-- Get a language object for formatDate and ucfirst.
 
local lang = mw.language.getContentLanguage()
 
local lang = mw.language.getContentLanguage()
  −
-- Define constants
  −
local CONFIG_MODULE = 'Module:Message box/configuration'
      
--------------------------------------------------------------------------------
 
--------------------------------------------------------------------------------
Line 108: Line 106:  
obj.categories = {}
 
obj.categories = {}
 
obj.classes = {}
 
obj.classes = {}
-- For lazy loading of [[Module:Category handler]].
  −
obj.hasCategories = false
      
return setmetatable(obj, MessageBox)
 
return setmetatable(obj, MessageBox)
Line 123: Line 119:  
cat = string.format('[[Category:%s]]', cat)
 
cat = string.format('[[Category:%s]]', cat)
 
end
 
end
self.hasCategories = true
   
self.categories[ns] = self.categories[ns] or {}
 
self.categories[ns] = self.categories[ns] or {}
 
table.insert(self.categories[ns], cat)
 
table.insert(self.categories[ns], cat)
Line 159: Line 154:     
-- Add attributes, classes and styles.
 
-- Add attributes, classes and styles.
self.id = args.id
+
if cfg.allowId then
if yesno(args.plainlinks) ~= false then
+
self.id = args.id
self:addClass('plainlinks')
   
end
 
end
 +
self:addClass(
 +
cfg.usePlainlinksParam and yesno(args.plainlinks or true) and 'plainlinks'
 +
)
 
for _, class in ipairs(cfg.classes or {}) do
 
for _, class in ipairs(cfg.classes or {}) do
 
self:addClass(class)
 
self:addClass(class)
Line 283: Line 280:  
end
 
end
 
self.info = args.info
 
self.info = args.info
if yesno(args.removalnotice) then
  −
self.removalNotice = cfg.removalNotice
  −
end
   
end
 
end
   Line 431: Line 425:     
function MessageBox:renderCategories()
 
function MessageBox:renderCategories()
if not self.hasCategories then
  −
-- No categories added, no need to pass them to Category handler so,
  −
-- if it was invoked, it would return the empty string.
  −
-- So we shortcut and return the empty string.
  −
return ""
  −
end
   
-- Convert category tables to strings and pass them through
 
-- Convert category tables to strings and pass them through
 
-- [[Module:Category handler]].
 
-- [[Module:Category handler]].
return require('Module:Category handler')._main{
+
return categoryHandler{
 
main = table.concat(self.categories[0] or {}),
 
main = table.concat(self.categories[0] or {}),
 
template = table.concat(self.categories[10] or {}),
 
template = table.concat(self.categories[10] or {}),
Line 503: Line 491:  
-- collapsible. At the moment, only ambox uses this.
 
-- collapsible. At the moment, only ambox uses this.
 
textCell:cssText(self.textstyle or nil)
 
textCell:cssText(self.textstyle or nil)
local textCellDiv = textCell:tag('div')
+
local textCellSpan = textCell:tag('span')
textCellDiv
+
textCellSpan
 
:addClass('mbox-text-span')
 
:addClass('mbox-text-span')
 
:wikitext(self.issue or nil)
 
:wikitext(self.issue or nil)
if (self.talk or self.fix) and not self.isSmall then
+
if not self.isSmall then
textCellDiv:tag('span')
+
textCellSpan:tag('span')
 
:addClass('hide-when-compact')
 
:addClass('hide-when-compact')
 
:wikitext(self.talk and (' ' .. self.talk) or nil)
 
:wikitext(self.talk and (' ' .. self.talk) or nil)
 
:wikitext(self.fix and (' ' .. self.fix) or nil)
 
:wikitext(self.fix and (' ' .. self.fix) or nil)
 
end
 
end
textCellDiv:wikitext(self.date and (' ' .. self.date) or nil)
+
textCellSpan:wikitext(self.date and (' ' .. self.date) or nil)
if self.info and not self.isSmall then
+
if not self.isSmall then
textCellDiv
+
textCellSpan
 
:tag('span')
 
:tag('span')
 
:addClass('hide-when-compact')
 
:addClass('hide-when-compact')
 
:wikitext(self.info and (' ' .. self.info) or nil)
 
:wikitext(self.info and (' ' .. self.info) or nil)
end
  −
if self.removalNotice then
  −
textCellDiv:tag('small')
  −
:addClass('hide-when-compact')
  −
:tag('i')
  −
:wikitext(string.format(" (%s)", self.removalNotice))
   
end
 
end
 
else
 
else
Line 585: Line 567:     
function p.main(boxType, args, cfgTables)
 
function p.main(boxType, args, cfgTables)
local box = MessageBox.new(boxType, args, cfgTables or mw.loadData(CONFIG_MODULE))
+
local box = MessageBox.new(boxType, args, cfgTables or mw.loadData('Module:Message box/configuration'))
 
box:setParameters()
 
box:setParameters()
 
box:setCategories()
 
box:setCategories()
Anonymous user

Navigation menu