Jump to content
 







Main menu
   


Navigation  



Main page
Contents
Current events
Random article
About Wikipedia
Contact us
Donate
 




Contribute  



Help
Learn to edit
Community portal
Recent changes
Upload file
 








Search  

































Create account

Log in
 









Create account
 Log in
 




Pages for logged out editors learn more  



Contributions
Talk
 



















Contents

   



(Top)
 


1 Use from wikitext  





2 Use from other Lua modules  





3 Technical details  














Module:Category main article






Аԥсшәа
العربية
Արեւմտահայերէն
Авар
تۆرکجه
Basa Bali

Banjar
 / Bân-lâm-gú
Беларуская (тарашкевіца)

Bosanski
Буряад
Cebuano
فارسی
Fiji Hindi

  / Gõychi Konknni

ि
Ilokano
Bahasa Indonesia
Jawa








Português
Sakizaya
سرائیکی

کوردی
Српски / srpski
Tagalog
ி

Тоҷикӣ
Türkmençe
اردو
Tiếng Vit

Zazaki

 

Edit links
 









Module
Talk
 

















Read
View source
View history
 








Tools
   


Actions  



Read
View source
View history
 




General  



What links here
Related changes
Upload file
Special pages
Permanent link
Page information
Get shortened URL
Download QR code
Wikidata item
 




Print/export  



Download as PDF
Printable version
 




In other projects  



Wikiquote
 
















Appearance
   

 





Permanently protected module

From Wikipedia, the free encyclopedia
 


This module produces hatnote saying "The main article for this category is x." It implements the {{Category main article}} template.

Use from wikitext

This module should usually be used via the {{Category main article}} template. However, it can also be used from #invoke with the syntax {{#invoke:Category main article|catMain|parameters}}. Please see the {{Category main article}} template documentation for available parameters.

Use from other Lua modules

Load the module:

local mCatMain = require('Module:Category main article')

You can then use the _catMain function like this:

mCatMain._catMain(options, ...)

options is an optional table that can be used to configure the function's output. There are two available options, "article" and "selfref".

The remaining arguments are page names to be turned into link(s) following the text "The main article for this category is". If no page names are specified, the current page name (minus the namespace name) is used for the first link.

Example 1
mCatMain._catMain(nil, 'Foo')

Produces:

<div class="hatnote relarticle mainarticle">The main article for this [[Help:Categories|category]] is '''[[Foo]]'''.</div>

Displays as:

Example 2
mCatMain._catMain(nil, 'Foo', 'Bar', 'Baz')

Produces:

<div class="hatnote relarticle mainarticle">The main articles for this [[Help:Categories|category]] are '''[[Foo]]''', '''[[Bar]]''' and '''[[Baz]]'''.</div>

Displays as:

Example 3
mCatMain._catMain({article = false}, 'Foo')

Produces:

<div class="hatnote relarticle mainarticle">The main page for this [[Help:Categories|category]] is '''[[Foo]]'''.</div>

Displays as:

Technical details

This module uses Module:Hatnote to format the hatnote text.

-- This module implements {{cat main}}.

local mHatnote = require('Module:Hatnote')
local mFormatLink = require('Module:Format link')
local yesno = require('Module:Yesno')
local mTableTools -- lazily initialise
local mArguments -- lazily initialise

local p = {}

function p.catMain(frame)
 mTableTools = require('Module:TableTools')
 mArguments = require('Module:Arguments')
 local args = mArguments.getArgs(frame, {wrappers = 'Template:Category main article'})
 local pages = mTableTools.compressSparseArray(args)
 local options = {
  article = args.article,
  selfref = args.selfref
 }
 return p._catMain(options, unpack(pages))
end

function p._catMain(options, ...)
 options = options or {}

 -- Get the links table.
 local links = mFormatLink.formatPages({}, {...})
 if not links[1] then
  local page = mw.title.getCurrentTitle().text
  links[1] = mFormatLink._formatLink{link = page}
 end
 for i, link in ipairs(links) do
  links[i] = string.format("'''%s'''", link)
 end

 -- Get the pagetype.
 local pages = {...}
 local pagetype 
 
 if options.article ~= nil then
  pagetype = yesno(options.article) ~= false and 'article' or 'page'
 elseif pages and pages[1] then
  local page = pages[1]:gsub("|.*","")
  pagetype = mw.title.new(page).namespace == 0 and "article" or "page"
 else
  pagetype = "article"
 end

 -- Work out whether we need to be singular or plural.
 local stringToFormat
 if #links > 1 then
  stringToFormat = 'The main %ss for this [[Help:Categories|category]] are %s.'
 else
  stringToFormat = 'The main %s for this [[Help:Categories|category]] is %s.'
 end

 -- Get the text.
 local text = string.format(
  stringToFormat,
  pagetype,
  mw.text.listToText(links)
 )
 
 -- Pass it through to Module:Hatnote.
 local hnOptions = {}
 hnOptions.selfref = options.selfref

 return mHatnote._hatnote(text, hnOptions)
end

return p

Retrieved from "https://en.wikipedia.org/w/index.php?title=Module:Category_main_article&oldid=1192627662"

Category: 
Hatnote modules
Hidden category: 
Wikipedia template-protected modules
 



This page was last edited on 30 December 2023, at 12:30 (UTC).

Text is available under the Creative Commons Attribution-ShareAlike License 4.0; additional terms may apply. By using this site, you agree to the Terms of Use and Privacy Policy. Wikipedia® is a registered trademark of the Wikimedia Foundation, Inc., a non-profit organization.



Privacy policy

About Wikipedia

Disclaimers

Contact Wikipedia

Code of Conduct

Developers

Statistics

Cookie statement

Mobile view



Wikimedia Foundation
Powered by MediaWiki