Module:Article stub box: Difference between revisions

Content deleted Content added
m irrelevant class name from template:param
Escape `{{` in output to avoid a Parsoid bug. See Wikipedia:AutoWikiBrowser/Tasks#c-Anomie-20250302162200-Anomie-20250302155000 for details.
 
(38 intermediate revisions by 11 users not shown)
Line 1:
--[[
local p = {
This module was created by User:CodeHydro (Alexander Zhikun He).
cats = {inv = {}}
User:Jackmcbarn and User:Mr._Stradivarius provided a great deal of assistance in writting p.main()
}
local WRAPPER_TEMPLATE = 'Template:Asbox'
local args, stubCats
 
p.main() draw heavily from the following version of Template:Asbox of the English Wikipedia, authored primarily by User:Rich_Farmbrough
function demo(text, alt)
https://en.wikipedia.org/w/index.php?title=Template:Asbox&oldid=619510287
return args.demo and text or alt
end
 
p.templatepage() is derived from the following revision of Template:Asbox/templatepage, authored primarily by User:MSGJ
local attention = 'Stub message templates needing attention'
https://en.wikipedia.org/w/index.php?title=Template:Asbox/templatepage&oldid=632914791
function category(cat)--{{'cat', 'sort'}, 'cat2'} or 'cat'
 
for _, v in ipairs(type(cat) == type'' and {cat} or cat) do
Both templates had significant contributions from numerous others listed in the revision history tab of their respective pages.
p.key = string.format(
--]]
'[[%sCategory:%s]]',
local WRAPPER_TEMPLATE, args = 'Template:Article stub box'
demo(':', ''),
-- TODO: update this instance of Asbox to Article stub box eventually
#v > 2 and v or string.format(
local templatestyles = 'Module:Article stub box/styles.css'
demo('%s|Category:%s|%s', '%s|%s%s'),
local p, Buffer, stubCats = {
#v[1] < 2 and attention or v[1],
--Prevents dupli-cats... get it? Maybe not?
#v[1] < 2 and attention or v[1],
cats = setmetatable({}, {__newindex = function(t, i, v)
#v[1] < 2 and table.concat(v) or v[2]
if not rawget(t, i) then
)
rawset(t, i, v)
)
table.insert(t, i)
if not p.cats.inv[p.key] then
end
table.insert(p.cats, p.key)
end}),
p.cats.inv[p.key] = #p.cats
--initializes variables required by both p.main and p.templatepage
init = function(self, frame, page)
args, page = args or require('Module:Arguments').getArgs(frame, {
wrappers = WRAPPER_TEMPLATE
}), page or mw.title.getCurrentTitle()
--Ensures demo parameter will never affect category() output for articles
self.demo = self.demo or page.namespace ~= 0 and args.demo
return args, page
end
}, require('Module:Buffer')
 
--[[
Formats category links. Stores them until called with cat.done=true
Takes multiple or single categories in the form of 'cat'
or a table of strings and/or tables containing parts. (See below)
]]
local attention, catTag, catKey = Buffer'Stub message templates needing attention', '[[Category:%s]]', '%s|%s%s'
local function category(cat)
for _, v in ipairs((tostring(cat) == cat or cat.t) and {cat} or cat) do
--[[
If v is a table:
[1] = full category name; defaults to local attention if blank
k = Category sort key. Prefix before v.t
t = page.text or args.tempsort#; appended after k (or in its place if omitted). Required if v is not a string
Basically the same as v = (v[1] or attention) .. ' | ' .. (v.k or '') .. v.t
]]
if v and v ~= true then--reject v = nil, false, or true
p.cats[catTag:format(tostring(v) == v and
v
or (v[1] and Buffer(v[1]) or attention):_in(v.k):_(v.t):_str(2, nil, nil, '|')
)] = true
end
end
return cat.done and table.concat(p.cats, p.demo( and ' | ', '')or nil) or ''
end
 
--[[
function ombox(v)--{text, {subcat, page}}
Makes an ombox warning;
if v.ifNot then
Takes table {ifNot = Boolean, text, {cat. sort key, cat. sort name}}
return ''
Will return an empty string instead when ifNot evaluates to true
end
]]
local function ombox(v)
if v.ifNot then return end
p.ombox = p.ombox or require('Module:Message box').ombox
category{v[2]}
Line 42 ⟶ 73:
end
 
--[[
function catStub(page, pageDoc)--p.templatepage passes page; p.main does not
Unlike original template, module now takes unlimited cats! This function also performs
stubCats = {
most stub category error checks except for the ombox for when main |category= is omitted (See p.template())
missing = {},
]]
S = {},
local function catStub(page, pageDoc)
v = {}
stubCats = {missing = {}, v = {}}
}
-- zwj and zwnj have semantical use in other other wikis, don't remove them
local zwj = '\226\128\141' -- U+200D, E2 80 8D
local zwnj = '\226\128\140' -- U+200C, E2 80 8C
local disallowedUnicodeChars = '[^%w%p%s' .. zwj .. zwnj .. ']' -- for i18n we make this a separate string
local code
for k, _ in pairs(args) do
--Find category parameters and store the number (main cat = '')
table.insert(stubCats, string.match(k, '^category(%d*)$'))
end
table.sort(stubCats)
local cat, tsort
for k, v in ipairs(stubCats) do
--Get category names and, if called by p.templatepage, the optional sort key
cat = args['category' .. v]
local tsort, cat = args['tempsort' .. v], mw.ustring.gsub(args['category' .. v], disallowedUnicodeChars, '')--remove all hidden unicode chars
--Do not place template in main category if |tempsort = 'no'. However, DO place articles of that template in the main category.
if v ~= '' or tsort ~= 'no' then
table.insert(stubCats.v, {cat, page and (tsort or ('*' .. page.text))})
page and (--p.templatepage passes page; p.main does not, i.e. articles are categorized without sort keys.
end
v=='' and tsort == 'no'--if true, inserts 'true' in table, which category() will reject
or tsort and {cat, k = ' ', t = tsort}
or {cat, k = ' *', t = page.text}--note space in front of sort key
)
or cat
)
--Check category existance only if on the template page (i.e. stub documentation)
if page then
if not mw.title.new('Category:' .. cat).exists then
tablecode = code or mw.insert(stubCatshtml.missing, create'code':wikitext'|category' .. v)
table.insert(stubCats.missing, tostring(mw.clone(code):wikitext(v)))
end
--[[
table.insert(stubCats.v,
Checks non-demo stub template for documentation and flags if doc is present.
v == '' and pageDoc.exists and
All stub cats names are checked and flagged if it does not match 'Category: [] stub'.
'Stub message templates with documentation subpages'
The main stub cat is exempt from the name check if the stub template has its own doc
or not string.match(cat, ' stubs$') and {'S', page.text}
(presumably, this doc would have an explanation as to why the main stub cat is non-conforming).
or nil
]]
table.insert(stubCats.v, v == '' and not p.demo and pageDoc.exists and
'Stub message templates with documentation subpages'
or not cat:match' stubs$' and {k = 'S', t = page.text}
)
end
end
--Add category names after loop is completed
if #stubCats.missing > 0 then
stubCats.missed = {}
for k, meowFeedMe in ipairs(stubCats.missing) do
table.insert(stubCats.missed, '<code>|' .. meowFeedMe .. '</code>')
end
end
category(stubCats.v)
return #stubCats.missedmissing > 0 and ombox{
--Changed, original msg:
--One or more of the stub categories defined in this template do not seem to exist!
--Please double-check the parameters {{para|category}}, {{para|category1}} and {{para|category2}}.
'The following parameter'
.. (#stubCats.missing == 1 and ' defines a stub category that does' or 's define stub categories that do')
.. ' not exist: ' .. mw.text.listToText(stubCats.missedmissing),
{k = 'N', t = page.text}
} or ''
end
 
--Shows population of categories found by catStub(). Outputs demo values if none
function population()
local function population()
local wikitext, base = ''{}, '* [[:Category:%s]] (population: (%s)\n'
if #not args.category and stubCats[1] =~= 0false then
table.insert(stubCats, 1, false)
return string.format(base, '{{{category}}}', 0)
end
for k_, v in ipairs(stubCats) do
table.insert(wikitext, base:format(
wikitext = wikitext .. string.format(base, args['category' .. v], mw.site.stats.pagesInCategory(args['category' .. v], 'all'))
v and args['category' .. v] or '{{{category}}}',
v and mw.site.stats.pagesInCategory(args['category' .. v], 'all') or 0
))
end
return table.concat(wikitext)
end
 
--Includes standard stub documention and flags stub templates with bad parameter values.
function p.templatepage(frame, page)--flags bad stub templates and creates standard doc page
function p.templatepage(frame, page)
local tStubDoc = mw.title.new('Template:Stub documentation')
args, page = p:init(frame, page)
local pageDoc = mw.title.new(page.fullText .. '/doc')
local tStubDoc = mw.title.new'Template:Stub documentation'
page = page or mw.title.getCurrentTitle()
local pageDoc = page:subPageTitle('doc')
args = args or require('Module:Arguments').getArgs(frame, {
--Reorganization note: Original Asbox alternates between outputting categories and checking on params |category#=.
wrappers = WRAPPER_TEMPLATE
--Rather than checking multiple times and switching tasks, all stub category param operations have been rolled into catStub()
})
return category{Buffer(
ombox{--Show ombox warnings for missing args.
'Stub message templates',
ifNot = args.category,
'Exclude in print',
'The <code>|category</code> parameter is not set. Please add an appropriate stub category.',
--Changed. Original Asbox does its first of 3 checks on params |category#= here.
{k = 'C', t = page.text}
--Rather than checking multiple times, all operations involving those params have been rolled into catStub()
})
(args.icon and
:_(ombox{
'Stub message templates using icon parameter'
ifNot = args.subject or (args.imagearticle andor args.qualifier,
'This stub template contains no description! At least one of the parameters <code>|subject</code>, <code>|article</code> or <code>|qualifier</code> must be defined.',
(mw.title.new('Media:' .. mw.text.split(args.image, '|')[1]).exists and
{k = 'D', t = page.text}
nil
})
or {'B', page.text}
:_(catStub(page, pageDoc))--catStub() may also return an ombox if there are non-existing categories
:_(category{
done = p.demo ~= 'doc',--Outputs categories if not doc demo
'Stub message templates',
args.icon and
'Stub message templates using icon parameter'
or args.image and (
mw.title.new('Media:' .. mw.text.split(args.image, '|')[1]).exists--do nothing if exists. category() will reject true
or {k = 'B', t = page.text}
)
or 'Stub message templates without images',
args.imagealt and {k = 'I', t = page.text},
)
}),
:_((not p.demo or p.demo == 'doc') and--Add standard stub template documentation
args.imagealt and {'I', page.text} or nil
require('Module:Documentation').main{
}
content = Buffer(page.text ~= 'Stub' and--This comparison performed in {{Asbox/stubtree}} before it invokes Module:Asbox stubtree
.. ombox{
-- TODO: update this instance of Asbox to Article stub box eventually
ifNot = args.category,
require('Module:Asbox stubtree').subtree{args = {pagename = page.text}}
'The <code>|category</code> parameter is not set. Please add an appropriate stub category.',
)
{'C', page.text}
:_in'\n== About this template ==\nThis template is used to identify a':_(args.subject):_'stub':_(args.qualifier):_out' '--space
}
:_'. It uses {{[[Template:Article stub box|article stub box]]}}, which is a meta-template designed to ease the process of creating and maintaining stub templates.\n=== Usage ===\nTyping '
.. ombox{
:_(mw.html.create'code'
ifNot = args.subject or args.article or args.qualifier,
:wikitext( mw.text.nowiki( '{{' ), page.text == 'Stub' and 'stub' or page.text, '}}')
'This stub template contains no description! At least one of the parameters <code>|subject</code>, <code>|article</code> or <code>|qualifier</code> must be defined.',
)
{'D', page.text}
:_' produces the message shown at the beginning, and adds the article to the following categor'
}
:_(#stubCats > 1 and 'ies' or 'y')
.. catStub(page, pageDoc)
:_':\n'
.. ((args.demo and args.demo ~= 'doc' and '') or (require('Module:Documentation').main{
:_(population())
content =
:_(pageDoc.exists and--transclusion of /doc if it exists
(page.text ~= 'Stub' and --This comparison performed in {{Asbox/stubtree}} before it invokes Module:Asbox stubtree
frame:expandTemplate{title = pageDoc.text}
require('Module:Asbox stubtree').subtree{args = {pagename = page.text}}
or '' )
:_'\n== General information ==\n'
)
:_(frame:expandTemplate{title = tStubDoc.text})
.. '\n== About this template ==\nThis template is used to identify a '
:_'\n\n'(),
.. string.format('%s stub%s.', args.subject or '', args.qualifier and (' ' .. args.qualifier) or '')
['link box'] = Buffer'This documentation is automatically generated by [[Module:Article stub box]].'
.. ' It uses {{[[Template:Asbox|asbox]]}}, which is a meta-template designed to ease the process of creating and maintaining stub templates.\n=== Usage ===\nTyping <code>{{'
:_in'The general information is transcluded from [[Template:Stub documentation]]. '
.. (page.text == 'Stub' and
:_(mw.html.create'stubspan'
:cssText'font-size:smaller;font-style:normal;line-height:130%'
or page.text
:node(('([%s edit] | [%s history])'):format(
)
tStubDoc:fullUrl('action=edit', 'relative'),
.. '}}</code> produces the message shown at the beginning, and adds the article to the following categor' .. (#stubCats > 1 and 'ies' or 'y') .. ':\n'
tStubDoc:fullUrl('action=history', 'relative')
.. population()
))
.. (pageDoc.exists and --transclusion of /doc if it exists
)
frame:expandTemplate{title = pageDoc.text}
or '' :_out()
:_(page.protectionLevels.edit and page.protectionLevels.edit[1] == 'sysop' and
)
"This template is [[WP:PROTECT|fully protected]] and any [[WP:CAT|categories]] should be added to the template's ["
.. '\n== General information ==\n'--Generic documentation
.. pageDoc:fullUrl('action=edit&preload=Template:Category_interwiki/preload', 'relative')
.. frame:expandTemplate{title = tStubDoc.text} .. '\n\n'
.. '| /doc] subpage, which is not protected.'
,
[ )'link box<br/>'] =
}
string.format(
)()
'This documentation is automatically generated by [[Template:Asbox/templatepage]].<br>The general information is transcluded from [[Template:Stub documentation]]. <span style="font-size:smaller;font-style:normal;line-height:130%%">([%s edit] | [%s history])</span>',
tStubDoc:fullUrl('action=edit', 'relative'),
tStubDoc:fullUrl('action=history', 'relative')
)
.. (page.protectionLevels.edit[1] == 'sysop' and
" <br/>This template is [[WP:PROTECT|fully protected]] and any [[WP:CAT|categories]] should be added to the template's ["
.. pageDoc:fullURL('action=edit&preload=Template:Category_interwiki/preload', 'relative')
.. '| /doc] subpage, which is not protected.'
or ''
)
}
.. (args.demo ~= 'doc' and category{done = true} or '')))
end
 
function p.main(frame, page)
args, page = p:init(frame, page)
page = page or mw.title.getCurrentTitle()
local output = mw.html.create'div'
args = args or require('Module:Arguments').getArgs(frame, {
:attr{role = 'note'}
wrappers = WRAPPER_TEMPLATE
:addClass'metadata plainlinks asbox stub'
})
:tag'table'
local output = mw.html.create()
:attr{role = 'presentation'}
local asbox = output:tag'table'
:tag'tr'
:addClass('metadata plainlinks stub')
:addClass'noresize'
:css('background', 'transparent')
:node((args.icon or args.image) and
:attr('role', 'presentation')
mw.html.create'td'
if args.icon or args.image then
asbox:tag('td') :wikitext(args.icon or string.('[[File:%s|%spx|alt=%s]]'):format(
args.image or '',
'[[File:%s|%spx|alt=%s]]',
args.imagepix or '40x30',
args.piximagealt or '40x30Stub icon',
))
args.imagealt or 'Stub icon'
) )
:tag'td'
end
:tag'p'
local buffer = asbox:tag('td')
:addClass'asbox-body'
buffer:tag('i'):wikitext(string.format(
:wikitext(
'This %s %s %s is a [[Wikipedia:stub|stub]]. You can help Wikipedia by [%s expanding it].',
Buffer'This':_(args.subject):_(args.article or 'article'):_(args.qualifier)' ',--space
' is a [[Wikipedia:stub|stub]]. You can help Wikipedia by [',
args.article or 'article',
page:fullUrl('action=edit', 'relative'),
args.qualifier or '',
' expanding it].'
page:fullUrl('action=edit', 'relative')
)
))
:done()
if args.name then
:node(args.note and
buffer:wikitext(require('Module:Navbar')._navbar{
mw.html.create()
args.name,
mini = :tag'yesp',
:addClass'asbox-note'
style = 'position: absolute; right: 15px; display: none;'
:wikitext(args.note)
})
:done()
end
)
if args.note then
buffer:tagallDone('br')
:node(args.name and
buffer:tag('span')
require'Module:Navbar'._navbar{
:css('font-style', 'normal')
args.name,
:css('font-size', 'smaller')
mini = 'yes',
:wikitext(args.note)
}
end
)
--[[
Stub categories for templates include a sort key; this ensures that all stub tags appear at the beginning of their respective categories.
Articles using the template do not need a sort key since they have unique names.
When p.demo equals 'doc', the demo stub categories will appear as those for a stub template.
Otherwise, any non-nil p.demo will emulate article space categories (plus any error cats unless set to 'art')
]]
if page.namespace == 0 then -- Main namespace
category'All stub articles'
catStub()
elseif argsp.demo then
if p.demo ~= 'doc' then catStub() end
--Preview categories; not in original template, but shouldn't hurt
--Unless p.demo is set to 'art', it will also include error categories normally only shown on
p.templatepage(frame, page)
--the template but not in the article. The elseif after namespace == 0 means demo cats will never show in article space.
table.sort(p.cats)
p.demodoc = p.demo ~= 'art' and p.templatepage(frame, page)
output:wikitext(string.format('<small>Demo categories: %s</small>', category{done = true}))
output = mw.html.create()
:node(output)
:tag'small':wikitext(
'Demo categories: ',
(category{done = true}:gsub('(%[%[)(Category:)([^|%]]-)(%|)', '%1%2%3|%2%3%4'):gsub('(%[%[)(Category:)', '%1:%2'))
):done()
:wikitext(p.demo == 'doc' and p.demodoc or nil)
else
--Checks for valid name; emulates original template's check using {{FULLPAGENAME:{{{name|}}}}}
local normalizedName = mw.title.new(args.name or '')
if normalizedName and normalizedName.fullText == page.fullText then
output = mw.html.create():node(output):wikitext(p.templatepage(frame, page))
elseif not page.isSubpage and page.namespace == 10 then -- Template namespace and not a subpage
category{{k = args.name and 'E' or 'W', t = page.text}}
end
end
return frame:extensionTag{ name = 'templatestyles', args = { src = templatestyles} } .. tostring(output:wikitext(not p.demo and category{done = true} or nil))
return output
:wikitext(
category{done = not args.demo},
args.demo == 'doc' and p.templatepage(frame, page) or nil
)
end