Module:Redirect template: Difference between revisions
Richardpruen (talk | contribs) m 1 revision imported |
Richardpruen (talk | contribs) m 1 revision imported: template update |
||
(5 intermediate revisions by 4 users not shown) | |||
Line 1: | Line 1: | ||
require(' | require('strict') | ||
local p = {} | local p = {} | ||
Line 11: | Line 11: | ||
help = { 12, '[[wp:help namespace|help]]' }, | help = { 12, '[[wp:help namespace|help]]' }, | ||
portal = { 100, '[[wp:portal|portal]]' }, | portal = { 100, '[[wp:portal|portal]]' }, | ||
talk = { function(n) return n > 0 and n%2 == 1 end, '[[Help: | talk = { function(n) return n > 0 and n%2 == 1 end, '[[Help:Talk pages|talk]]' }, | ||
template = { 10, '[[wp:template namespace|template]]' }, | template = { 10, '[[wp:template namespace|template]]' }, | ||
wikipedia = { 4, '[[wp:project namespace|Wikipedia project]]' }, | wikipedia = { 4, '[[wp:project namespace|Wikipedia project]]' }, | ||
category = { 14, '[[wp:categorization|category]]' }, | category = { 14, '[[wp:categorization|category]]' }, | ||
user = { 2, '[[wp:user pages|user]]' }, | user = { 2, '[[wp:user pages|user]]' }, | ||
draft = { 118, '[[wp:drafts|draft]]' }, | |||
} | } | ||
Line 42: | Line 43: | ||
local namespace = mw.title.getCurrentTitle().namespace | local namespace = mw.title.getCurrentTitle().namespace | ||
--- XXX: this is a HORRIBLE HACK. kill it with fire as soon as https://bugzilla.wikimedia.org/show_bug.cgi?id=12974 | --- XXX: this is a HORRIBLE HACK. kill it with fire as soon as https://phabricator.wikimedia.org/T14974 is fixed | ||
local | --- [[phab:T14974]] was previously known as [[bugzilla:12974]] https://bugzilla.wikimedia.org/show_bug.cgi?id=12974 | ||
local beCompatibleWithBug14974 = args.info and (args.info:find('^[:;#*]', 1) == 1 or args.info:find('{|', 1, true) == 1) and '\n' or ' ' | |||
local content = string.format('\n<div class="rcat %s">\n*%sThis is a redirect%s%s.%s%s\n</div>', | local content = string.format('\n<div class="rcat %s">\n*%sThis is a redirect%s%s.%s%s\n</div>', | ||
Line 50: | Line 52: | ||
args.from and (' from ' .. args.from) or '', | args.from and (' from ' .. args.from) or '', | ||
args.to and (' to ' .. args.to) or '', | args.to and (' to ' .. args.to) or '', | ||
args.info and | args.info and beCompatibleWithBug14974 or '', | ||
args.info or '' | args.info or '' | ||
) | ) | ||
Line 57: | Line 59: | ||
if args[k .. ' category'] then | if args[k .. ' category'] then | ||
if type(v[1]) == 'function' and v[1](namespace) or v[1] == namespace then | if type(v[1]) == 'function' and v[1](namespace) or v[1] == namespace then | ||
content = content .. string.format('[[Category:%s]]', args[k .. ' category']) | if args.sortkey then | ||
content = content .. string.format('[[Category:%s|%s]]', args[k .. ' category'], args.sortkey) | |||
else | |||
content = content .. string.format('[[Category:%s]]', args[k .. ' category']) | |||
end | |||
elseif args['other category'] then | elseif args['other category'] then | ||
content = content .. string.format('[[Category:%s]]', args['other category']) | if args.sortkey then | ||
content = content .. string.format('[[Category:%s|%s]]', args['other category'], args.sortkey) | |||
else | |||
content = content .. string.format('[[Category:%s]]', args['other category']) | |||
end | |||
else | else | ||
content = content .. frame:expandTemplate{title = 'Incorrect redirect template', args = {v[2]}} | content = content .. frame:expandTemplate{title = 'Incorrect redirect template', args = {v[2]}} |