Changes

Jump to navigation Jump to search
726 bytes added ,  15:56, 21 December 2018
add class using template name, code requested by User:SD0001
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 106: Line 108:  
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 119: Line 123:  
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 154: Line 159:     
-- Add attributes, classes and styles.
 
-- Add attributes, classes and styles.
if cfg.allowId then
+
self.id = args.id
self.id = args.id
+
self.name = args.name
 +
if self.name then
 +
self:addClass('box-' .. string.gsub(self.name,' ','_'))
 +
end
 +
if yesno(args.plainlinks) ~= false then
 +
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 182: Line 189:  
and cfg.templateCategoryRequireName
 
and cfg.templateCategoryRequireName
 
then
 
then
self.name = args.name
   
if self.name then
 
if self.name then
 
local templateName = mw.ustring.match(
 
local templateName = mw.ustring.match(
Line 194: Line 200:  
and mw.title.equals(self.title, self.templateTitle)
 
and mw.title.equals(self.title, self.templateTitle)
 
end
 
end
 
+
 
-- Process data for collapsible text fields. At the moment these are only
 
-- Process data for collapsible text fields. At the moment these are only
 
-- used in {{ambox}}.
 
-- used in {{ambox}}.
Line 277: Line 283:  
end
 
end
 
if date then
 
if date then
self.date = string.format(" <small>''(%s)''</small>", date)
+
self.date = string.format(" <small class='date-container'>''(<span class='date'>%s</span>)''</small>", date)
 
end
 
end
 
self.info = args.info
 
self.info = args.info
 +
if yesno(args.removalnotice) then
 +
self.removalNotice = cfg.removalNotice
 +
end
 
end
 
end
   Line 425: Line 434:     
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 categoryHandler{
+
return require('Module:Category handler')._main{
 
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 491: Line 506:  
-- 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 textCellSpan = textCell:tag('span')
+
local textCellDiv = textCell:tag('div')
textCellSpan
+
textCellDiv
 
:addClass('mbox-text-span')
 
:addClass('mbox-text-span')
 
:wikitext(self.issue or nil)
 
:wikitext(self.issue or nil)
if not self.isSmall then
+
if (self.talk or self.fix) and not self.isSmall then
textCellSpan:tag('span')
+
textCellDiv: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
textCellSpan:wikitext(self.date and (' ' .. self.date) or nil)
+
textCellDiv:wikitext(self.date and (' ' .. self.date) or nil)
if not self.isSmall then
+
if self.info and not self.isSmall then
textCellSpan
+
textCellDiv
 
: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 567: Line 588:     
function p.main(boxType, args, cfgTables)
 
function p.main(boxType, args, cfgTables)
local box = MessageBox.new(boxType, args, cfgTables or mw.loadData('Module:Message box/configuration'))
+
local box = MessageBox.new(boxType, args, cfgTables or mw.loadData(CONFIG_MODULE))
 
box:setParameters()
 
box:setParameters()
 
box:setCategories()
 
box:setCategories()
Anonymous user

Navigation menu