Module:Collapsible list/sandbox: Difference between revisions
Appearance
Content deleted Content added
gotta return that root Tag: Reverted |
why clist can't have nice things MediaWiki_talk:Common.css/Archive_15#plainlist_+_hlist_indentation |
||
Line 1: | Line 1: | ||
local p = {} |
local p = {} |
||
local list_mod = require('Module:List') |
|||
local function gettitlestyletracking( ts ) |
local function gettitlestyletracking( ts ) |
||
Line 15: | Line 14: | ||
end |
end |
||
return '[[Category:Pages using collapsible list without both background and text-align in titlestyle|' .. skey .. ' ]]' |
return '[[Category:Pages using collapsible list without both background and text-align in titlestyle|' .. skey .. ' ]]' |
||
end |
|||
local function getListItem( data ) |
|||
if not type( data ) == 'string' then |
|||
return '' |
|||
end |
|||
return mw.ustring.format( '<li style="line-height: inherit; margin: 0">%s</li>', data ) |
|||
end |
end |
||
Line 32: | Line 38: | ||
table.sort( nums ) |
table.sort( nums ) |
||
return nums |
return nums |
||
end |
|||
-- Formats a list of classes, styles or other attributes. |
|||
local function formatAttributes( attrType, ... ) |
|||
local attributes = { ... } |
|||
local nums = getArgNums( attributes ) |
|||
local t = {} |
|||
for i, num in ipairs( nums ) do |
|||
table.insert( t, attributes[ num ] ) |
|||
end |
|||
if #t == 0 then |
|||
return '' -- Return the blank string so concatenation will work. |
|||
end |
|||
return mw.ustring.format( ' %s="%s"', attrType, table.concat( t, ' ' ) ) |
|||
end |
end |
||
Line 38: | Line 58: | ||
local listItems = {} |
local listItems = {} |
||
local argNums = getArgNums( args ) |
local argNums = getArgNums( args ) |
||
for |
for i, num in ipairs( argNums ) do |
||
table.insert( listItems, |
table.insert( listItems, getListItem( args[ num ] ) ) |
||
end |
end |
||
if #listItems == 0 then |
if #listItems == 0 then |
||
return '' |
return '' |
||
end |
end |
||
listItems = table.concat( listItems ) |
|||
-- hack around mw-collapsible show/hide jumpiness by looking for text-alignment |
-- hack around mw-collapsible show/hide jumpiness by looking for text-alignment |
||
Line 50: | Line 71: | ||
local centeredTitle = (args.title_style and args.title_style:lower():match(textAlignmentCentered) |
local centeredTitle = (args.title_style and args.title_style:lower():match(textAlignmentCentered) |
||
or args.titlestyle and args.titlestyle:lower():match(textAlignmentCentered)) |
or args.titlestyle and args.titlestyle:lower():match(textAlignmentCentered)) |
||
local centeredTitleSpacing |
local centeredTitleSpacing |
||
if centeredTitle then |
|||
centeredTitleSpacing = 'margin: 0 4em' |
|||
else |
|||
-- pass default attributes to Module:List |
|||
⚫ | |||
listItems['class'] = 'mw-collapsible-content' |
|||
local list_style = '' |
|||
if args.list_style then list_style = list_style .. args.list_style end |
|||
if args.liststyle then list_style = list_style .. args.liststyle end |
|||
listItems['list_style'] = list_style |
|||
local list = 'unbulleted' |
|||
⚫ | |||
list = 'horizontal' |
|||
elseif args.bullets then |
|||
list = 'bulleted' |
|||
end |
end |
||
-- Get class, style and title data. |
|||
local root = mw.html.create() |
|||
local collapsibleContainerClass = formatAttributes( |
|||
root:tag('div') |
|||
'class', |
|||
:addClass('collapsible-list mw-collapsible') |
|||
'mw-collapsible', not args.expand and 'mw-collapsed' |
|||
) |
|||
local collapsibleContainerStyle = formatAttributes( |
|||
-- text align set to counteract the pull of .infobox-full-data |
|||
'style', |
|||
-- leaving it to be centered probably wouldn't hurt anyone though |
|||
'text-align: center; font-size: 100%;', |
|||
-- so add a TODO for someone to look at/think about in the future |
|||
args.frame_style, |
|||
:cssText('text-align: left;') |
|||
args.framestyle |
|||
⚫ | |||
:cssText(args.framestyle) |
|||
local collapsibleTitleStyle = formatAttributes( |
|||
:tag('div') |
|||
'style', |
|||
:addClass('collapsible-list-title') |
|||
'line-height: 1.6em; font-weight: bold; font-size: 100%; text-align: left;', |
|||
args.title_style, |
|||
args.titlestyle |
|||
) |
|||
local jumpyTitleStyle = formatAttributes( |
|||
⚫ | |||
'style', |
|||
centeredTitleSpacing |
|||
:done() |
|||
) |
|||
local title = args.title or 'List' |
|||
:wikitext(list_mod[list](listItems)) |
|||
local ulclass = formatAttributes( 'class', 'mw-collapsible-content', args.hlist and 'hlist' ) |
|||
⚫ | |||
local ulstyle = formatAttributes( |
|||
⚫ | |||
'style', |
|||
return tostring(root) |
|||
'font-size: 100%; margin-top: 0; margin-bottom: 0; line-height: inherit; text-align: left;', |
|||
not args.bullets and 'list-style: none; margin-left: 0;', |
|||
args.list_style, |
|||
args.liststyle |
|||
) |
|||
local hlist_templatestyles = '' |
|||
⚫ | |||
hlist_templatestyles = mw.getCurrentFrame():extensionTag{ |
|||
name = 'templatestyles', args = { src = 'Hlist/styles.css' } |
|||
} |
|||
end |
|||
-- Build the list. |
|||
return mw.ustring.format( |
|||
'%s<div%s%s>\n<div%s><div%s>%s</div></div>\n<ul%s%s>%s</ul>\n</div>', |
|||
hlist_templatestyles, collapsibleContainerClass, collapsibleContainerStyle, |
|||
collapsibleTitleStyle, jumpyTitleStyle, title, ulclass, ulstyle, listItems |
|||
⚫ | |||
end |
end |
||
Revision as of 02:49, 29 December 2022
![]() | This is the module sandbox page for Module:Collapsible list (diff). |
![]() | This Lua module is used on 63,000+ pages and changes may be widely noticed. Test changes in the module's /sandbox or /testcases subpages, or in your own module sandbox. Consider discussing changes on the talk page before implementing them. |
![]() | This module is rated as ready for general use. It has reached a mature form and is thought to be relatively bug-free and ready for use wherever appropriate. It is ready to mention on help pages and other Wikipedia resources as an option for new users to learn. To reduce server load and bad output, it should be improved by sandbox testing rather than repeated trial-and-error editing. |
![]() | This module is subject to page protection. It is a highly visible module in use by a very large number of pages, or is substituted very frequently. Because vandalism or mistakes would affect many pages, and even trivial editing might cause substantial load on the servers, it is protected from editing. |
![]() | This module uses TemplateStyles: |
This module implements {{collapsible list}}. Please see the template page for documentation.
local p = {}
local function gettitlestyletracking( ts )
if not ts then return '' end
ts = mw.ustring.gsub(mw.ustring.lower(ts), '%s', '')
local tsvals = mw.text.split(ts, ';')
table.sort(tsvals)
local skey = table.concat(tsvals,';')
skey = mw.ustring.gsub(skey, '^;', '')
skey = mw.text.encode(mw.text.encode(skey),'%c%[%]=')
if (mw.ustring.match(';' .. ts, ';background:') or mw.ustring.match(';' .. ts, ';background%-color:'))
and mw.ustring.match(';' .. ts, ';text%-align:') then
return '[[Category:Pages using collapsible list with both background and text-align in titlestyle|' .. skey .. ' ]]'
end
return '[[Category:Pages using collapsible list without both background and text-align in titlestyle|' .. skey .. ' ]]'
end
local function getListItem( data )
if not type( data ) == 'string' then
return ''
end
return mw.ustring.format( '<li style="line-height: inherit; margin: 0">%s</li>', data )
end
-- Returns an array containing the keys of all positional arguments
-- that contain data (i.e. non-whitespace values).
local function getArgNums( args )
local nums = {}
for k, v in pairs( args ) do
if type( k ) == 'number' and
k >= 1 and
math.floor( k ) == k and
type( v ) == 'string' and
mw.ustring.match( v, '%S' ) then
table.insert( nums, k )
end
end
table.sort( nums )
return nums
end
-- Formats a list of classes, styles or other attributes.
local function formatAttributes( attrType, ... )
local attributes = { ... }
local nums = getArgNums( attributes )
local t = {}
for i, num in ipairs( nums ) do
table.insert( t, attributes[ num ] )
end
if #t == 0 then
return '' -- Return the blank string so concatenation will work.
end
return mw.ustring.format( ' %s="%s"', attrType, table.concat( t, ' ' ) )
end
local function buildList( args )
-- Get the list items.
local listItems = {}
local argNums = getArgNums( args )
for i, num in ipairs( argNums ) do
table.insert( listItems, getListItem( args[ num ] ) )
end
if #listItems == 0 then
return ''
end
listItems = table.concat( listItems )
-- hack around mw-collapsible show/hide jumpiness by looking for text-alignment
-- by setting a margin if centered
local textAlignmentCentered = 'text%-align%s*:%s*center'
local centeredTitle = (args.title_style and args.title_style:lower():match(textAlignmentCentered)
or args.titlestyle and args.titlestyle:lower():match(textAlignmentCentered))
local centeredTitleSpacing
if centeredTitle then
centeredTitleSpacing = 'margin: 0 4em'
else
centeredTitleSpacing = ''
end
-- Get class, style and title data.
local collapsibleContainerClass = formatAttributes(
'class',
'mw-collapsible', not args.expand and 'mw-collapsed'
)
local collapsibleContainerStyle = formatAttributes(
'style',
'text-align: center; font-size: 100%;',
args.frame_style,
args.framestyle
)
local collapsibleTitleStyle = formatAttributes(
'style',
'line-height: 1.6em; font-weight: bold; font-size: 100%; text-align: left;',
args.title_style,
args.titlestyle
)
local jumpyTitleStyle = formatAttributes(
'style',
centeredTitleSpacing
)
local title = args.title or 'List'
local ulclass = formatAttributes( 'class', 'mw-collapsible-content', args.hlist and 'hlist' )
local ulstyle = formatAttributes(
'style',
'font-size: 100%; margin-top: 0; margin-bottom: 0; line-height: inherit; text-align: left;',
not args.bullets and 'list-style: none; margin-left: 0;',
args.list_style,
args.liststyle
)
local hlist_templatestyles = ''
if args.hlist then
hlist_templatestyles = mw.getCurrentFrame():extensionTag{
name = 'templatestyles', args = { src = 'Hlist/styles.css' }
}
end
-- Build the list.
return mw.ustring.format(
'%s<div%s%s>\n<div%s><div%s>%s</div></div>\n<ul%s%s>%s</ul>\n</div>',
hlist_templatestyles, collapsibleContainerClass, collapsibleContainerStyle,
collapsibleTitleStyle, jumpyTitleStyle, title, ulclass, ulstyle, listItems
) .. gettitlestyletracking(args.title_style or args.titlestyle)
end
function p.main( frame )
local origArgs
if frame == mw.getCurrentFrame() then
origArgs = frame:getParent().args
for k, v in pairs( frame.args ) do
origArgs = frame.args
break
end
else
origArgs = frame
end
local args = {}
for k, v in pairs( origArgs ) do
if type( k ) == 'number' or v ~= '' then
args[ k ] = v
end
end
return buildList( args )
end
return p