Ce module, importé de w:en:Module:TOC avec {{List TOC}}, permet de créer des sommaires, notamment pour catégories.
La documentation de ce module est générée par le modèle {{Documentation module}}.
Elle est incluse depuis la page Module:TOC/Documentation. Veuillez placer les catégories sur cette page-là.
Les éditeurs peuvent travailler dans le bac à sable (créer).
Voir les statistiques d'appel depuis le wikicode sur l'outil wstat et les appels depuis d'autres modules.
-- This module implements various templates that create custom tables of
-- contents.
-- Load necessary modules
local checkType = require('libraryUtil').checkType
local p = {}
local function makeTocLink(page, display)
display = display or page
return string.format(']', page, display)
end
local function makeToc(s, args)
-- Make a TOC box from a string and from the given table of arguments.
checkType('makeToc', 1, s, 'string')
checkType('makeToc', 2, args, 'table', true)
args = args or {}
-- Root
local root = mw.html.create()
root:wikitext('__NOTOC__')
-- Top div tag
local top = root:tag('div')
top:addClass('toc plainlinks hlist')
if isPrimary then
top:attr('id', 'toc')
end
local align = args.align and args.align:lower()
if align == 'left' then
top
:css('float', 'left')
:css('clear', args.clear or 'left')
elseif align == 'right' then
top
:css('float', 'right')
:css('clear', args.clear or 'right')
elseif align == 'center' then
top
:css('margin', 'auto')
:css('clear', args.clear or 'none')
else
top
:css('clear', args.clear or 'left')
end
top:newline()
-- Title div tag
local title = args.title or mw.message.new('Toc'):plain()
local titleDiv = top:tag('div')
titleDiv:attr('id', 'toctitle')
if isPrimary then
titleDiv:wikitext('<h2>' .. title .. '</h2>')
else
titleDiv:tag('strong'):wikitext(title)
end
-- Content
top
:newline()
:wikitext(s)
:newline()
return tostring(root)
end
function p._years(args)
local i = tonumber(args.startyear) or 1900
local endYear = tonumber(args.endyear) or 1950
local range = tonumber(args.range)
local step = tonumber(args.step) or 1
local links = {}
while i <= endYear do
local year = tostring(i)
if range then
year = year .. '-' .. tostring(i + range)
end
links = makeTocLink(year)
i = i + step
end
if #links > 0 then
links = table.concat(links, ' ')
return makeToc(links, args)
else
return ''
end
end
function p._list(args)
-- Set up the variables.
local noRows = 4 -- The number of rows, starting at key "a". Must be 26 or less.
local alphabetPosition = 3 -- The position of the extra alphabet row.
local lists, chars = {}, {}
for i = 1, noRows do
lists = {}
end
-- Find the relevant keys from the arguments.
local a = 97
local endChar = string.char(a + noRows - 1)
local pattern = string.format('^()(*)$', endChar)
for k, v in pairs(args) do
local letter, num
if type(k) == 'string' then
letter, num = k:match(pattern)
end
if letter then
local iRow = string.byte(letter) - a + 1
table.insert(lists, {num = tonumber(num), section = v})
end
end
-- Sort the tables and replace the value tables with the section name.
for i, valueTables in pairs(lists) do
table.sort(valueTables, function(t1, t2)
return t1.num < t2.num
end)
for j, valueTable in ipairs(valueTables) do
lists = valueTable.section
end
end
-- Add the extra alphabet row.
local A = 65
local alphabetRow = {}
for i = 1, 26 do
local char = string.char(A + i - 1)
alphabetRow = char
end
table.insert(lists, alphabetPosition, alphabetRow)
-- Render the rows.
local ret = {}
for i, sections in ipairs(lists) do
if #sections > 0 then
ret = '<div>'
for j, section in ipairs(sections) do
ret = makeTocLink(section)
end
ret = '</div>'
end
end
return makeToc(table.concat(ret, ' · '), args)
end
-- Pour les catégories par langue du Wiktionnaire
function p._sommaire(frame)
local code = frame.args
if (code == nil) then
code = "fr"
end
local lettres = mw.loadData('Module:langues/alphabets')
alphabet = lettres
if alphabet == nil then
alphabet = lettres
end
local profondeur = frame.args
if (profondeur == nil) then
profondeur = 1
end
return makeToc(alphabet, frame.args)
end
return p