మాడ్యూల్:Main: కూర్పుల మధ్య తేడాలు
Jump to navigation
Jump to search
Content deleted Content added
Tweaked tracking to make exclusive to mainspace |
Updated from sandbox |
||
పంక్తి 9: | పంక్తి 9: | ||
local mHatnote = require('Module:Hatnote') |
local mHatnote = require('Module:Hatnote') |
||
⚫ | |||
local mTableTools -- lazily initialise |
|||
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}) |
||
పంక్తి 21: | పంక్తి 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 |
||
string.format('%s|%s', string.gsub(v, '|.*$', ''), display) or v |
|||
pages[ |
pages[#pages + 1] = page |
||
end |
end |
||
end |
end |
||
⚫ | |||
pages = mTableTools.compressSparseArray(pages) |
|||
return mHatnote.makeWikitextError( |
|||
'no page names specified', |
|||
'Template:Main#Errors', |
|||
args.category |
|||
) |
|||
⚫ | |||
local options = { |
local options = { |
||
selfref = args.selfref |
selfref = args.selfref |
||
} |
} |
||
return p._main( |
return p._main(pages, options) |
||
end |
end |
||
function p._main( |
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 pages = {...} |
|||
local currentTitle = mw.title.getCurrentTitle() |
local currentTitle = mw.title.getCurrentTitle() |
||
if #args == 0 then args = {currentTitle.text} end |
|||
local firstPageTable = pages[1] |
|||
local firstPage |
local firstPage = string.gsub(args[1], '|.*$', '') |
||
⚫ | |||
not firstPageTable) and |
|||
'[[Category:Hatnote templates using unusual parameters]]' or '' |
|||
if firstPageTable then |
|||
firstPage = firstPageTable[1] |
|||
else |
|||
⚫ | |||
firstPageTable = {firstPage} |
|||
pages[1] = firstPageTable |
|||
⚫ | |||
-- Find the pagetype. |
-- Find the pagetype. |
||
local |
local pageType = mHatnote.findNamespaceId(firstPage) == 0 and 'article' or 'page' |
||
local pagetype = firstPageNs == 0 and 'article' or 'page' |
|||
pagetype = pagetype .. emptyArgs |
|||
-- Make the formatted link text |
-- Make the formatted link text |
||
list = mHatlist.andList(args, true) |
|||
local links = mHatnote.formatPageTables(unpack(pages)) |
|||
links = mw.text.listToText(links) |
|||
-- Build the text. |
-- Build the text. |
||
local isPlural = # |
local isPlural = #args > 1 |
||
local mainForm |
|||
local currentNs = currentTitle.namespace |
|||
⚫ | |||
local isCategoryNamespace = currentNs - currentNs % 2 == 14 |
|||
if (curNs == 14) or (curNs == 15) then --category/talk namespaces |
|||
local stringToFormat |
|||
⚫ | |||
if isCategoryNamespace then |
|||
⚫ | |||
⚫ | |||
or |
|||
stringToFormat = 'The main %ss for this' |
|||
'The main %s for this [[Wikipedia:Categorization|category]] is %s' |
|||
else |
|||
stringToFormat = 'The main %s for this' |
|||
⚫ | |||
end |
|||
else |
else |
||
mainForm = isPlural and 'Main %ss: %s' or 'Main %s: %s' |
|||
stringToFormat = 'Main %ss: %s' |
|||
else |
|||
stringToFormat = 'Main %s: %s' |
|||
end |
|||
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]]. |
13:58, 28 జూన్ 2016 నాటి కూర్పు
--[[
-- 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 [[Wikipedia:Categorization|category]] are %s'
or
'The main %s for this [[Wikipedia:Categorization|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 = {
extraclasses = 'relarticle mainarticle',
selfref = options.selfref
}
return mHatnote._hatnote(text, hnOptions)
end
return p