Module:Shortcut: Difference between revisions

From the Croc Wiki, the Croc encyclopedia
Jump to navigationJump to search
m
9 revisions imported: Originally imported from Wikipedia.
(calculate the number of list items based on a table of list items, rather than doing it ad hoc from the shortcuts plus whatever else we want to add)
m (9 revisions imported: Originally imported from Wikipedia.)
 
(22 intermediate revisions by 9 users not shown)
Line 6:
-- Load required modules
local checkType = require('libraryUtil').checkType
local yesno = require('Module:Yesno')
 
local p = {}
 
local function message(msg, ...)
return mw.message.newRawMessage(msg, ...):plain()
end
 
local function makeCategoryLink(cat)
return string.format('[[%s:%s]]', mw.site.namespaces[14].name, cat)
end
 
function p._main(shortcuts, options, frame, cfg)
Line 15 ⟶ 24:
frame = frame or mw.getCurrentFrame()
cfg = cfg or mw.loadData(CONFIG_MODULE)
local templateMode = options.template and yesno(options.template)
local redirectMode = options.redirect and yesno(options.redirect)
local isCategorized = not options.category or yesno(options.category) ~= false
 
-- Validate shortcuts
for i, shortcut in ipairs(shortcuts) do
if type(shortcut) ~= 'string' or #shortcut < 1 then
error(message(cfg['invalid-shortcut-error'], i), 2)
error(string.format(
'shortcut #%d was invalid (shortcuts must be strings of ' ..
'at least one character in length)'
), 2)
end
end
Line 30 ⟶ 39:
local listItems = {}
for i, shortcut in ipairs(shortcuts) do
local templatePath, prefix
listItems[i] = string.format('[[%s]]', shortcut)
if templateMode then
-- Namespace detection
local titleObj = mw.title.new(shortcut, 10)
if titleObj.namespace == 10 then
templatePath = titleObj.fullText
else
templatePath = shortcut
end
prefix = options['pre' .. i] or options.pre or ''
end
if options.target and yesno(options.target) then
listItems[i] = templateMode
and string.format("&#123;&#123;%s[[%s|%s]]&#125;&#125;", prefix, templatePath, shortcut)
or string.format("[[%s]]", shortcut)
else
listItems[i] = frame:expandTemplate{
title = 'No redirect',
args = templateMode and {templatePath, shortcut} or {shortcut, shortcut}
}
if templateMode then
listItems[i] = string.format("&#123;&#123;%s%s&#125;&#125;", prefix, listItems[i])
end
end
end
table.insert(listItems, options.msg)
local nListItems = #listItems
 
-- ExitReturn an error if we have nothing to display
if nListItems#listItems < 1 then
local msg = cfg['no-content-error']
return nil
msg = string.format('<strong class="error">%s</strong>', msg)
if isCategorized and cfg['no-content-error-category'] then
msg = msg .. makeCategoryLink(cfg['no-content-error-category'])
end
return msg
end
 
local root = mw.html.create()
root:wikitext(frame:extensionTag{ name = 'templatestyles', args = { src = 'Shortcut/styles.css'} })
 
-- Anchors
local anchorDiv = root
:tag('div')
:addClass('module-shortcutanchordiv')
:css('position', 'relative')
:css('top', '-3em')
for i, shortcut in ipairs(shortcuts) do
local anchor = mw.uri.anchorEncode(shortcut)
anchorDiv:tag('span'):attr('id', anchor)
end
 
root:newline() -- To match the old [[Template:Shortcut]]
 
-- Shortcut heading
local shortcutHeading = mw.message.newRawMessage(
do
cfg['shortcut-heading'],
local nShortcuts = #shortcuts
nListItems
if nShortcuts > 0 then
):plain()
local headingMsg = options['shortcut-heading'] or
shortcutHeading = frame:preprocess(shortcutHeading)
redirectMode and cfg['redirect-heading'] or
cfg['shortcut-heading']
shortcutHeading = message(headingMsg, nShortcuts)
shortcutHeading = frame:preprocess(shortcutHeading)
end
end
 
-- Shortcut box
local shortcutList = root
:tag('tablediv')
:addClass('shortcutboxmodule-shortcutboxplain plainlist noprint')
:cssattr('floatrole', 'rightnote')
if options.float and options.float:lower() == 'left' then
:css('border', '1px solid #aaa')
shortcutList:addClass('module-shortcutboxleft')
:css('background', '#fff')
:css('margin', '.3em .3em .3em 1em')
:css('padding', '3px')
:css('text-align', 'center')
:tag('tr')
:tag('th')
:addClass('plainlist')
:css('border', 'none')
:css('background', 'transparent')
:tag('small')
:wikitext(shortcutHeading)
:newline()
:tag('ul')
for i, item in ipairs(listItems) do
shortcutList:tag('li'):wikitext(item)
end
if options.clear and options.clear ~= '' then
 
shortcutList:css('clear', options.clear)
-- Error category
end
if shortcuts[1] then
if shortcutHeading then
local title = mw.title.new(shortcuts[1])
shortcutList
if not title or not title.exists then
:tag('div')
root:wikitext(string.format(
:addClass('module-shortcutlist')
'[[%s:%s]]',
:wikitext(shortcutHeading)
mw.site.namespaces[14].name,
end
cfg['first-parameter-error-category']
local list = shortcutList:tag('ul')
))
for i, item in ipairs(listItems) do
end
list:tag('li'):wikitext(item)
end
 
return tostring(root)
end
 
function p.main(frame)
local args = require('Module:Arguments').getArgs(frame, {)
wrappers = 'Template:Shortcut'
})
 
-- Separate shortcuts from options
Cookies help us deliver our services. By using our services, you agree to our use of cookies.

Navigation menu