Module:Shortcut: Difference between revisions
Jump to navigation
Jump to search
Content deleted Content added
use the number of shortcuts to generate the plural for the shortcut heading, rather than the number of list items; also, don't output the heading if we don't have any shortcuts to display |
m 1 revision imported Tags: Mobile edit Mobile web edit |
||
(23 intermediate revisions by 12 users not shown) | |||
Line 5: | Line 5: | ||
-- Load required modules |
-- Load required modules |
||
local yesno = require('Module:Yesno') |
|||
local checkType = require('libraryUtil').checkType |
local checkType = require('libraryUtil').checkType |
||
local yesno = require('Module:Yesno') |
|||
local p = {} |
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) |
function p._main(shortcuts, options, frame, cfg) |
||
Line 16: | Line 24: | ||
frame = frame or mw.getCurrentFrame() |
frame = frame or mw.getCurrentFrame() |
||
cfg = cfg or mw.loadData(CONFIG_MODULE) |
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 |
-- Validate shortcuts |
||
for i, shortcut in ipairs(shortcuts) do |
for i, shortcut in ipairs(shortcuts) do |
||
if type(shortcut) ~= 'string' or #shortcut < 1 then |
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 |
||
end |
end |
||
Line 31: | Line 39: | ||
local listItems = {} |
local listItems = {} |
||
for i, shortcut in ipairs(shortcuts) do |
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("{{%s[[%s|%s]]}}", 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("{{%s%s}}", prefix, listItems[i]) |
|||
end |
|||
end |
|||
end |
end |
||
table.insert(listItems, options.msg) |
table.insert(listItems, options.msg) |
||
-- |
-- Return an error if we have nothing to display |
||
if #listItems < 1 then |
if #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 |
end |
||
local root = mw.html.create() |
local root = mw.html.create() |
||
root:wikitext(frame:extensionTag{ name = 'templatestyles', args = { src = 'Module:Shortcut/styles.css'} }) |
|||
-- Anchors |
-- Anchors |
||
local anchorDiv = root |
local anchorDiv = root |
||
:tag('div') |
:tag('div') |
||
:addClass('module-shortcutanchordiv') |
|||
:css('position', 'relative') |
|||
:css('top', '-3em') |
|||
for i, shortcut in ipairs(shortcuts) do |
for i, shortcut in ipairs(shortcuts) do |
||
local anchor = mw.uri.anchorEncode(shortcut) |
local anchor = mw.uri.anchorEncode(shortcut) |
||
anchorDiv:tag('span'):attr('id', anchor) |
anchorDiv:tag('span'):attr('id', anchor) |
||
end |
end |
||
root:newline() -- To match the old [[Template:Shortcut]] |
|||
-- Shortcut heading |
-- Shortcut heading |
||
Line 59: | Line 92: | ||
local nShortcuts = #shortcuts |
local nShortcuts = #shortcuts |
||
if nShortcuts > 0 then |
if nShortcuts > 0 then |
||
local headingMsg = options['shortcut-heading'] or |
|||
shortcutHeading = mw.message.newRawMessage( |
|||
cfg[' |
redirectMode and cfg['redirect-heading'] or |
||
cfg['shortcut-heading'] |
|||
nShortcuts |
|||
shortcutHeading = message(headingMsg, nShortcuts) |
|||
):plain() |
|||
shortcutHeading = frame:preprocess(shortcutHeading) |
shortcutHeading = frame:preprocess(shortcutHeading) |
||
shortcutHeading = shortcutHeading .. '\n' |
|||
end |
end |
||
end |
end |
||
Line 70: | Line 102: | ||
-- Shortcut box |
-- Shortcut box |
||
local shortcutList = root |
local shortcutList = root |
||
:tag(' |
:tag('div') |
||
:addClass(' |
:addClass('module-shortcutboxplain noprint') |
||
: |
:attr('role', 'note') |
||
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) |
|||
:tag('ul') |
|||
for i, item in ipairs(listItems) do |
|||
shortcutList:tag('li'):wikitext(item) |
|||
end |
end |
||
if options.clear and options.clear ~= '' then |
|||
shortcutList:css('clear', options.clear) |
|||
-- Error category |
|||
if shortcuts[1] and not yesno(options.nocat) then |
|||
local title = mw.title.new(shortcuts[1]) |
|||
if not title or not title.exists then |
|||
root:wikitext(string.format( |
|||
'[[%s:%s]]', |
|||
mw.site.namespaces[14].name, |
|||
cfg['first-parameter-error-category'] |
|||
)) |
|||
end |
|||
end |
end |
||
if shortcutHeading then |
|||
shortcutList |
|||
:tag('div') |
|||
:addClass('module-shortcutlist') |
|||
:wikitext(shortcutHeading) |
|||
end |
|||
local ubl = require('Module:List').unbulleted(listItems) |
|||
shortcutList:wikitext(ubl) |
|||
return tostring(root) |
return tostring(root) |
||
end |
end |
||
function p.main(frame) |
function p.main(frame) |
||
local args = require('Module:Arguments').getArgs(frame |
local args = require('Module:Arguments').getArgs(frame) |
||
wrappers = 'Template:Shortcut' |
|||
}) |
|||
-- Separate shortcuts from options |
-- Separate shortcuts from options |
Latest revision as of 06:56, 11 April 2024
This module is licensed under CC-BY-SA 4.0, as it has been imported from Wikipedia.
-- This module implements {{shortcut}}.
-- Set constants
local CONFIG_MODULE = 'Module:Shortcut/config'
-- 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)
checkType('_main', 1, shortcuts, 'table')
checkType('_main', 2, options, 'table', true)
options = options or {}
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)
end
end
-- Make the list items. These are the shortcuts plus any extra lines such
-- as options.msg.
local listItems = {}
for i, shortcut in ipairs(shortcuts) do
local templatePath, prefix
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("{{%s[[%s|%s]]}}", 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("{{%s%s}}", prefix, listItems[i])
end
end
end
table.insert(listItems, options.msg)
-- Return an error if we have nothing to display
if #listItems < 1 then
local msg = cfg['no-content-error']
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 = 'Module:Shortcut/styles.css'} })
-- Anchors
local anchorDiv = root
:tag('div')
:addClass('module-shortcutanchordiv')
for i, shortcut in ipairs(shortcuts) do
local anchor = mw.uri.anchorEncode(shortcut)
anchorDiv:tag('span'):attr('id', anchor)
end
-- Shortcut heading
local shortcutHeading
do
local nShortcuts = #shortcuts
if nShortcuts > 0 then
local headingMsg = options['shortcut-heading'] or
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('div')
:addClass('module-shortcutboxplain noprint')
:attr('role', 'note')
if options.float and options.float:lower() == 'left' then
shortcutList:addClass('module-shortcutboxleft')
end
if options.clear and options.clear ~= '' then
shortcutList:css('clear', options.clear)
end
if shortcutHeading then
shortcutList
:tag('div')
:addClass('module-shortcutlist')
:wikitext(shortcutHeading)
end
local ubl = require('Module:List').unbulleted(listItems)
shortcutList:wikitext(ubl)
return tostring(root)
end
function p.main(frame)
local args = require('Module:Arguments').getArgs(frame)
-- Separate shortcuts from options
local shortcuts, options = {}, {}
for k, v in pairs(args) do
if type(k) == 'number' then
shortcuts[k] = v
else
options[k] = v
end
end
-- Compress the shortcut array, which may contain nils.
local function compressArray(t)
local nums, ret = {}, {}
for k in pairs(t) do
nums[#nums + 1] = k
end
table.sort(nums)
for i, num in ipairs(nums) do
ret[i] = t[num]
end
return ret
end
shortcuts = compressArray(shortcuts)
return p._main(shortcuts, options, frame)
end
return p