Module:Main: Difference between revisions
Content added Content deleted
(unpack the table used for formatPageTables) |
(update after changes to Module:Hatnote) |
||
Line 27: | Line 27: | ||
end |
end |
||
pages = mTableTools.compressSparseArray(pages) |
pages = mTableTools.compressSparseArray(pages) |
||
local options = { |
|||
⚫ | |||
selfref = args.selfref |
|||
} |
|||
⚫ | |||
end |
end |
||
function p._main(...) |
function p._main(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. |
||
Line 46: | Line 49: | ||
-- Find the pagetype. |
-- Find the pagetype. |
||
local firstPageNs = mHatnote. |
local firstPageNs = mHatnote.findNamespaceId(firstPage) |
||
local pagetype = firstPageNs == 0 and 'article' or 'page' |
local pagetype = firstPageNs == 0 and 'article' or 'page' |
||
-- Make the formatted link text |
-- Make the formatted link text |
||
local links = mHatnote. |
local links = mHatnote.formatPageTables(unpack(pages)) |
||
links = mw.text.listToText(links) |
links = mw.text.listToText(links) |
||
Line 75: | Line 78: | ||
local text = string.format(stringToFormat, pagetype, links) |
local text = string.format(stringToFormat, pagetype, links) |
||
-- |
-- Process the options and pass the text to the _rellink function in |
||
-- [[Module:Hatnote]]. |
|||
⚫ | |||
options = options or {} |
|||
⚫ | |||
local hnOptions = { |
|||
⚫ | |||
selfref = options.selfref |
|||
} |
|||
⚫ | |||
end |
end |
||
Revision as of 16:53, 2 May 2014
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 mTableTools -- lazily initialise
local mArguments -- lazily initialise
local p = {}
function p.main(frame)
mTableTools = require('Module:TableTools')
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['l' .. tostring(k)]
local page = {v, display}
pages[k] = page
end
end
pages = mTableTools.compressSparseArray(pages)
local options = {
selfref = args.selfref
}
return p._main(options, unpack(pages))
end
function p._main(options, ...)
-- Get the list of pages. If no first page was specified we use the current
-- page name.
local pages = {...}
local currentTitle = mw.title.getCurrentTitle()
local firstPageTable = pages[1]
local firstPage
if firstPageTable then
firstPage = firstPageTable[1]
else
firstPage = currentTitle.text
firstPageTable = {firstPage}
pages[1] = firstPageTable
end
-- Find the pagetype.
local firstPageNs = mHatnote.findNamespaceId(firstPage)
local pagetype = firstPageNs == 0 and 'article' or 'page'
-- Make the formatted link text
local links = mHatnote.formatPageTables(unpack(pages))
links = mw.text.listToText(links)
-- Build the text.
local isPlural = #pages > 1
local currentNs = currentTitle.namespace
local isCategoryNamespace = currentNs - currentNs % 2 == 14
local stringToFormat
if isCategoryNamespace then
if isPlural then
stringToFormat = 'The main %ss for this'
.. ' [[Wikipedia:Categorization|category]] are %s'
else
stringToFormat = 'The main %s for this'
.. ' [[Wikipedia:Categorization|category]] is %s'
end
else
if isPlural then
stringToFormat = 'Main %ss: %s'
else
stringToFormat = 'Main %s: %s'
end
end
local text = string.format(stringToFormat, pagetype, links)
-- Process the options and pass the text to the _rellink function in
-- [[Module:Hatnote]].
options = options or {}
local hnOptions = {
extraclasses = 'relarticle mainarticle',
selfref = options.selfref
}
return mHatnote._hatnote(text, hnOptions)
end
return p