Module:Main: Difference between revisions
m 1 revision |
m 1 revision imported |
||
(One intermediate revision by one other user not shown) | |||
Line 4: | Line 4: | ||
-- | -- | ||
-- If the module is used in category or category talk space, it produces "The | -- If the module is used in category or category talk space, it produces "The | ||
-- main article for this category is xxx" | -- main article for this category is xxx." Otherwise, it produces | ||
-- "Main article: xxx". | -- "Main article: xxx". | ||
--]] | --]] | ||
local mHatnote = require('Module:Hatnote') | local mHatnote = require('Module:Hatnote') | ||
local | local mHatlist = require('Module:Hatnote list') | ||
local mArguments -- lazily initialise | local mArguments -- lazily initialise | ||
local p = {} | local p = {} | ||
function p.main(frame) | function p.main(frame) | ||
mArguments = require('Module:Arguments') | mArguments = require('Module:Arguments') | ||
local args = mArguments.getArgs(frame, {parentOnly = true}) | local args = mArguments.getArgs(frame, {parentOnly = true}) | ||
Line 21: | Line 19: | ||
for k, v in pairs(args) do | for k, v in pairs(args) do | ||
if type(k) == 'number' then | if type(k) == 'number' then | ||
local display = args['l' .. | local display = args['label ' .. k] or args['l' .. k] | ||
local page = | local page = display and | ||
pages[ | string.format('%s|%s', string.gsub(v, '|.*$', ''), display) or v | ||
pages[#pages + 1] = page | |||
end | end | ||
end | end | ||
pages = | if #pages == 0 and mw.title.getCurrentTitle().namespace == 0 then | ||
return mHatnote.makeWikitextError( | |||
'no page names specified', | |||
'Template:Main#Errors', | |||
args.category | |||
) | |||
end | |||
local options = { | local options = { | ||
selfref = args.selfref | selfref = args.selfref | ||
} | } | ||
return p._main(options | return p._main(pages, options) | ||
end | end | ||
function p._main(options | function p._main(args, options) | ||
-- Get the list of pages. If no first page was specified we use the current | -- Get the list of pages. If no first page was specified we use the current | ||
-- page name. | -- page name. | ||
local currentTitle = mw.title.getCurrentTitle() | local currentTitle = mw.title.getCurrentTitle() | ||
if #args == 0 then args = {currentTitle.text} end | |||
local firstPage = string.gsub(args[1], '|.*$', '') | |||
-- Find the pagetype. | -- Find the pagetype. | ||
local | local pageType = mHatnote.findNamespaceId(firstPage) == 0 and 'article' or 'page' | ||
-- Make the formatted link text | -- Make the formatted link text | ||
list = mHatlist.andList(args, true) | |||
-- Build the text. | -- Build the text. | ||
local isPlural = # | local isPlural = #args > 1 | ||
local | local mainForm | ||
local curNs = currentTitle.namespace | |||
if (curNs == 14) or (curNs == 15) then --category/talk namespaces | |||
mainForm = isPlural and | |||
'The main %ss for this [[Help:Categories|category]] are %s.' | |||
or | |||
'The main %s for this [[Help:Categories|category]] is %s.' | |||
else | else | ||
mainForm = isPlural and 'Main %ss: %s' or 'Main %s: %s' | |||
end | end | ||
local text = string.format( | local text = string.format(mainForm, pageType, list) | ||
-- Process the options and pass the text to the _rellink function in | -- Process the options and pass the text to the _rellink function in | ||
-- [[Module:Hatnote]]. | -- [[Module:Hatnote]]. | ||
options = options or {} | options = options or {} | ||
local hnOptions = { | local hnOptions = { | ||
selfref = options.selfref | selfref = options.selfref | ||
} | } |
Latest revision as of 18:42, 7 July 2021
Documentation for this module may be created at Module:Main/doc
--[[
-- This module produces a link to a main article or articles. It implements the
-- template {{main}}.
--
-- If the module is used in category or category talk space, it produces "The
-- main article for this category is xxx." Otherwise, it produces
-- "Main article: xxx".
--]]
local mHatnote = require('Module:Hatnote')
local mHatlist = require('Module:Hatnote list')
local mArguments -- lazily initialise
local p = {}
function p.main(frame)
mArguments = require('Module:Arguments')
local args = mArguments.getArgs(frame, {parentOnly = true})
local pages = {}
for k, v in pairs(args) do
if type(k) == 'number' then
local display = args['label ' .. k] or args['l' .. k]
local page = display and
string.format('%s|%s', string.gsub(v, '|.*$', ''), display) or v
pages[#pages + 1] = page
end
end
if #pages == 0 and mw.title.getCurrentTitle().namespace == 0 then
return mHatnote.makeWikitextError(
'no page names specified',
'Template:Main#Errors',
args.category
)
end
local options = {
selfref = args.selfref
}
return p._main(pages, options)
end
function p._main(args, options)
-- Get the list of pages. If no first page was specified we use the current
-- page name.
local currentTitle = mw.title.getCurrentTitle()
if #args == 0 then args = {currentTitle.text} end
local firstPage = string.gsub(args[1], '|.*$', '')
-- Find the pagetype.
local pageType = mHatnote.findNamespaceId(firstPage) == 0 and 'article' or 'page'
-- Make the formatted link text
list = mHatlist.andList(args, true)
-- Build the text.
local isPlural = #args > 1
local mainForm
local curNs = currentTitle.namespace
if (curNs == 14) or (curNs == 15) then --category/talk namespaces
mainForm = isPlural and
'The main %ss for this [[Help:Categories|category]] are %s.'
or
'The main %s for this [[Help:Categories|category]] is %s.'
else
mainForm = isPlural and 'Main %ss: %s' or 'Main %s: %s'
end
local text = string.format(mainForm, pageType, list)
-- Process the options and pass the text to the _rellink function in
-- [[Module:Hatnote]].
options = options or {}
local hnOptions = {
selfref = options.selfref
}
return mHatnote._hatnote(text, hnOptions)
end
return p