Template link general: Difference between revisions
From Aurora Wiki
More actions
Content deleted Content added
Template>Primefac put subst on if nolink |
m 1 revision imported |
||
| (2 intermediate revisions by 2 users not shown) | |||
| Line 1: | Line 1: | ||
-- This implements Template:Template link general and various other templates in its family |
-- This implements [[Template:Template link general]] and various other templates in its family |
||
local getArgs = require('Module:Arguments').getArgs |
local getArgs = require('Module:Arguments').getArgs |
||
local yesno = require('Module:Yesno') |
|||
local cfg = mw.loadData('Module:Template link general/config') |
|||
local p = {} |
local p = {} |
||
-- Is a string non-empty? |
-- Is a string non-empty? |
||
local function _ne(s) |
local function _ne(s) |
||
return s ~= nil and s ~= "" |
return s ~= nil and s ~= "" |
||
end |
end |
||
| Line 26: | Line 30: | ||
local needle = 'template:' |
local needle = 'template:' |
||
if s:sub(1, needle:len()):lower() == needle then |
if s:sub(1, needle:len()):lower() == needle then |
||
return s:sub(needle:len() + 1) |
return s:sub(needle:len() + 1) |
||
else |
else |
||
return s |
return s |
||
| Line 33: | Line 37: | ||
local function linkTitle(args) |
local function linkTitle(args) |
||
if |
if yesno(args.nolink) then |
||
return args[1] |
|||
return 'subst:' .. args['1'] |
|||
else |
|||
return args['1'] |
|||
end |
|||
end |
end |
||
local titleObj |
local titleObj |
||
local titlePart = '[[' |
local titlePart = '[[' |
||
if args[ |
if args[1] then |
||
-- This handles :Page and other NS |
-- This handles :Page and other NS |
||
titleObj = mw.title.new(args[ |
titleObj = mw.title.new(args[1], 'Template') |
||
else |
else |
||
titleObj = mw.title.getCurrentTitle() |
titleObj = mw.title.getCurrentTitle() |
||
end |
end |
||
titlePart = titlePart .. (titleObj ~= nil and titleObj.fullText or |
titlePart = titlePart .. (titleObj ~= nil and titleObj.fullText or |
||
addTemplate(args[ |
addTemplate(args[1])) |
||
local textPart = args.alttext |
local textPart = args.alttext |
||
if not _ne(textPart) then |
if not _ne(textPart) then |
||
if titleObj ~= nil then |
if titleObj ~= nil then |
||
textPart = titleObj:inNamespace("Template") and args[ |
textPart = titleObj:inNamespace("Template") and args[1] or titleObj.fullText |
||
else |
else |
||
-- redlink |
-- redlink |
||
textPart = args[ |
textPart = args[1] |
||
end |
end |
||
end |
end |
||
if |
if yesno(args.brace) then |
||
-- HACK: the ns thing above is probably broken |
|||
textPart = 'subst:' .. textPart |
|||
end |
|||
if _ne(args.brace) then |
|||
textPart = nw('{{') .. textPart .. nw('}}') |
textPart = nw('{{') .. textPart .. nw('}}') |
||
elseif |
elseif yesno(args.braceinside) then |
||
textPart = nw('{') .. textPart .. nw('}') |
textPart = nw('{') .. textPart .. nw('}') |
||
end |
end |
||
titlePart = titlePart .. '|' .. textPart .. ']]' |
titlePart = titlePart .. '|' .. textPart .. ']]' |
||
if |
if yesno(args.braceinside) then |
||
titlePart = nw('{') .. titlePart .. nw('}') |
titlePart = nw('{') .. titlePart .. nw('}') |
||
end |
end |
||
| Line 84: | Line 79: | ||
local args = getArgs(frame, { |
local args = getArgs(frame, { |
||
trim = true, |
trim = true, |
||
removeBlanks = false |
removeBlanks = false, |
||
frameOnly = false, |
|||
wrappers = { |
|||
"Template:Tlg", |
|||
"Template:Template link general", |
|||
}, |
|||
}) |
}) |
||
return p._main(args) |
return p._main(args) |
||
| Line 90: | Line 90: | ||
function p._main(args) |
function p._main(args) |
||
-- TemplateStyles |
|||
local bold = _ne(args.bold) or _ne(args.boldlink) or _ne(args.boldname) |
|||
local templateStyles = { |
|||
local italic = _ne(args.italic) or _ne(args.italics) |
|||
mono = false, |
|||
local dontBrace = _ne(args.brace) or _ne(args.braceinside) |
|||
nowrap = false, |
|||
local code = _ne(args.code) or _ne(args.tt) |
|||
} |
|||
local show_result = _ne(args._show_result) |
|||
local expand = _ne(args._expand) |
|||
local bold = yesno(args.bold) or yesno(args.boldlink) or yesno(args.boldname) |
|||
local italic = yesno(args.italic) or yesno(args.italics) |
|||
local dontBrace = yesno(args.brace) or yesno(args.braceinside) |
|||
local code = yesno(args.code) or yesno(args.tt) |
|||
local show_result = yesno(args._show_result) |
|||
local expand = yesno(args._expand) |
|||
local classes = {} |
|||
-- Build the link part |
-- Build the link part |
||
local titlePart = linkTitle(args) |
local titlePart = linkTitle(args) |
||
if bold then titlePart = "'''" .. titlePart .. "'''" end |
if bold then titlePart = "'''" .. titlePart .. "'''" end |
||
if _ne(args.nowrapname) then titlePart = '<span class="nowrap">' .. titlePart .. '</span>' end |
|||
if yesno(args.subst) then |
|||
local substLink = cfg['subst-link'] |
|||
if _ne(substLink) and yesno(args['link subst']) then |
|||
titlePart = '[[' .. substLink .. '|subst]]:' .. titlePart |
|||
else |
|||
titlePart = 'subst:' .. titlePart |
|||
end |
|||
end |
|||
if yesno(args.nowrapname) then |
|||
templateStyles.nowrap = true |
|||
titlePart = '<span class="nowrap">' .. titlePart .. '</span>' |
|||
end |
|||
-- Build the arguments |
-- Build the arguments |
||
local textPart = "" |
local textPart = "" |
||
| Line 112: | Line 132: | ||
local val = args[i] |
local val = args[i] |
||
if val ~= "" then |
if val ~= "" then |
||
if |
if yesno(args.nowiki) then |
||
-- Unstrip nowiki tags first because calling nw on something that already contains nowiki tags will |
-- Unstrip nowiki tags first because calling nw on something that already contains nowiki tags will |
||
-- mangle the nowiki strip marker and result in literal UNIQ...QINU showing up |
-- mangle the nowiki strip marker and result in literal UNIQ...QINU showing up |
||
| Line 132: | Line 152: | ||
i = i + 1 |
i = i + 1 |
||
end |
end |
||
local tagName = nil |
|||
local css = nil |
|||
-- final wrap |
-- final wrap |
||
local ret = titlePart .. textPart |
local ret = titlePart .. textPart |
||
if not dontBrace then ret = nw('{{') .. ret .. nw('}}') end |
if not dontBrace then ret = nw('{{') .. ret .. nw('}}') end |
||
if |
if yesno(args.a) then ret = nw('*') .. ' ' .. ret end |
||
if |
if yesno(args.kbd) then |
||
tagName = 'kbd' |
|||
if code then |
|||
end |
|||
ret = '<code>' .. ret .. '</code>' |
|||
elseif _ne(args.plaincode) then |
|||
if yesno(args.mono) then |
|||
ret = '<code style="border:none;background:transparent;color:inherit">' .. ret .. '</code>' |
|||
templateStyles.mono = true |
|||
table.insert(classes, 'monospaced') |
|||
end |
|||
local plaincode = yesno(args.plaincode) and not code |
|||
if code or plaincode then |
|||
if tagName then |
|||
-- kbd == true && code == true |
|||
ret = ('<%s>%s</%s>'):format(tagName, ret, tagName) |
|||
end |
|||
tagName = 'code' |
|||
if plaincode then |
|||
css = { |
|||
background = 'transparent', |
|||
border = 'none', |
|||
color = 'var(--color-emphasized, #101418)', |
|||
} |
|||
end |
|||
end |
end |
||
if _ne(args.nowrap) then ret = '<span class="nowrap">' .. ret .. '</span>' end |
|||
--[[ Wrap as html?? |
|||
local span = mw.html.create('span') |
|||
span:wikitext(ret) |
|||
--]] |
|||
if _ne(args.debug) then ret = ret .. '\n<pre>' .. mw.text.encode(mw.dumpObject(args)) .. '</pre>' end |
|||
if show_result then |
if show_result then |
||
| Line 163: | Line 197: | ||
end |
end |
||
if yesno(args.nowrap) then |
|||
return ret |
|||
templateStyles.nowrap = true |
|||
table.insert(classes, 'nowrap') |
|||
end |
|||
if tagName or #classes > 0 or css then |
|||
local span = mw.html.create(tagName or 'span') |
|||
:addClass(table.concat(classes, ' ')) |
|||
:wikitext(ret) |
|||
if css then |
|||
span:css(css) |
|||
end |
|||
ret = tostring(span:allDone()) |
|||
end |
|||
local ts = {} |
|||
if templateStyles.mono then |
|||
table.insert(ts, mw.getCurrentFrame():extensionTag{ |
|||
name = 'templatestyles', |
|||
args = { src = 'Template:Mono/styles.css' } |
|||
}) |
|||
end |
|||
if templateStyles.nowrap then |
|||
table.insert(ts, mw.getCurrentFrame():extensionTag{ |
|||
name = 'templatestyles', |
|||
args = { src = 'Template:Nowrap/styles.css' } |
|||
}) |
|||
end |
|||
if yesno(args.debug) then |
|||
ret = ret .. '\n<pre>' .. mw.text.encode(mw.dumpObject(args)) .. '</pre>' |
|||
end |
|||
return table.concat(ts) .. ret |
|||
end |
end |
||
Latest revision as of 10:19, 7 March 2025
Documentation for this module may be created at Module:Template link general/doc
-- This implements [[Template:Template link general]] and various other templates in its family
local getArgs = require('Module:Arguments').getArgs
local yesno = require('Module:Yesno')
local cfg = mw.loadData('Module:Template link general/config')
local p = {}
-- Is a string non-empty?
local function _ne(s)
return s ~= nil and s ~= ""
end
local nw = mw.text.nowiki
local function addTemplate(s)
local i, _ = s:find(':', 1, true)
if i == nil then
return 'Template:' .. s
end
local ns = s:sub(1, i - 1)
if ns == '' or mw.site.namespaces[ns] then
return s
else
return 'Template:' .. s
end
end
local function trimTemplate(s)
local needle = 'template:'
if s:sub(1, needle:len()):lower() == needle then
return s:sub(needle:len() + 1)
else
return s
end
end
local function linkTitle(args)
if yesno(args.nolink) then
return args[1]
end
local titleObj
local titlePart = '[['
if args[1] then
-- This handles :Page and other NS
titleObj = mw.title.new(args[1], 'Template')
else
titleObj = mw.title.getCurrentTitle()
end
titlePart = titlePart .. (titleObj ~= nil and titleObj.fullText or
addTemplate(args[1]))
local textPart = args.alttext
if not _ne(textPart) then
if titleObj ~= nil then
textPart = titleObj:inNamespace("Template") and args[1] or titleObj.fullText
else
-- redlink
textPart = args[1]
end
end
if yesno(args.brace) then
textPart = nw('{{') .. textPart .. nw('}}')
elseif yesno(args.braceinside) then
textPart = nw('{') .. textPart .. nw('}')
end
titlePart = titlePart .. '|' .. textPart .. ']]'
if yesno(args.braceinside) then
titlePart = nw('{') .. titlePart .. nw('}')
end
return titlePart
end
function p.main(frame)
local args = getArgs(frame, {
trim = true,
removeBlanks = false,
frameOnly = false,
wrappers = {
"Template:Tlg",
"Template:Template link general",
},
})
return p._main(args)
end
function p._main(args)
-- TemplateStyles
local templateStyles = {
mono = false,
nowrap = false,
}
local bold = yesno(args.bold) or yesno(args.boldlink) or yesno(args.boldname)
local italic = yesno(args.italic) or yesno(args.italics)
local dontBrace = yesno(args.brace) or yesno(args.braceinside)
local code = yesno(args.code) or yesno(args.tt)
local show_result = yesno(args._show_result)
local expand = yesno(args._expand)
local classes = {}
-- Build the link part
local titlePart = linkTitle(args)
if bold then titlePart = "'''" .. titlePart .. "'''" end
if yesno(args.subst) then
local substLink = cfg['subst-link']
if _ne(substLink) and yesno(args['link subst']) then
titlePart = '[[' .. substLink .. '|subst]]:' .. titlePart
else
titlePart = 'subst:' .. titlePart
end
end
if yesno(args.nowrapname) then
templateStyles.nowrap = true
titlePart = '<span class="nowrap">' .. titlePart .. '</span>'
end
-- Build the arguments
local textPart = ""
local textPartBuffer = "|"
local codeArguments = {}
local codeArgumentsString = ""
local i = 2
local j = 1
while args[i] do
local val = args[i]
if val ~= "" then
if yesno(args.nowiki) then
-- Unstrip nowiki tags first because calling nw on something that already contains nowiki tags will
-- mangle the nowiki strip marker and result in literal UNIQ...QINU showing up
val = nw(mw.text.unstripNoWiki(val))
end
local k, v = string.match(val, "(.*)=(.*)")
if not k then
codeArguments[j] = val
j = j + 1
else
codeArguments[k] = v
end
codeArgumentsString = codeArgumentsString .. textPartBuffer .. val
if italic then
val = '<span style="font-style:italic;">' .. val .. '</span>'
end
textPart = textPart .. textPartBuffer .. val
end
i = i + 1
end
local tagName = nil
local css = nil
-- final wrap
local ret = titlePart .. textPart
if not dontBrace then ret = nw('{{') .. ret .. nw('}}') end
if yesno(args.a) then ret = nw('*') .. ' ' .. ret end
if yesno(args.kbd) then
tagName = 'kbd'
end
if yesno(args.mono) then
templateStyles.mono = true
table.insert(classes, 'monospaced')
end
local plaincode = yesno(args.plaincode) and not code
if code or plaincode then
if tagName then
-- kbd == true && code == true
ret = ('<%s>%s</%s>'):format(tagName, ret, tagName)
end
tagName = 'code'
if plaincode then
css = {
background = 'transparent',
border = 'none',
color = 'var(--color-emphasized, #101418)',
}
end
end
if show_result then
local result = mw.getCurrentFrame():expandTemplate{title = addTemplate(args[1]), args = codeArguments}
ret = ret .. " → " .. result
end
if expand then
local query = mw.text.encode('{{' .. addTemplate(args[1]) .. string.gsub(codeArgumentsString, textPartBuffer, "|") .. '}}')
local url = mw.uri.fullUrl('special:ExpandTemplates', 'wpInput=' .. query)
mw.log()
ret = ret .. " [" .. tostring(url) .. "]"
end
if yesno(args.nowrap) then
templateStyles.nowrap = true
table.insert(classes, 'nowrap')
end
if tagName or #classes > 0 or css then
local span = mw.html.create(tagName or 'span')
:addClass(table.concat(classes, ' '))
:wikitext(ret)
if css then
span:css(css)
end
ret = tostring(span:allDone())
end
local ts = {}
if templateStyles.mono then
table.insert(ts, mw.getCurrentFrame():extensionTag{
name = 'templatestyles',
args = { src = 'Template:Mono/styles.css' }
})
end
if templateStyles.nowrap then
table.insert(ts, mw.getCurrentFrame():extensionTag{
name = 'templatestyles',
args = { src = 'Template:Nowrap/styles.css' }
})
end
if yesno(args.debug) then
ret = ret .. '\n<pre>' .. mw.text.encode(mw.dumpObject(args)) .. '</pre>'
end
return table.concat(ts) .. ret
end
return p