Module:Collapsible list: Difference between revisions

Jump to navigation Jump to search
(we need to get back to this. since module loading depends on parsercache, these pages are missing modules now and it takes long for all pages to be invalidate. Will return later.)
 
m (1 revision imported)
 
(6 intermediate revisions by 4 users not shown)
Line 1: Line 1:
-- This module implements {{collapsible list}}.
local p = {}
local p = {}


Line 41: Line 39:
end
end


-- TODO: use Module:List. Since the update for this comment is routine,
-- this is blocked without a consensus discussion by
-- [[MediaWiki_talk:Common.css/Archive_15#plainlist_+_hlist_indentation]]
-- if we decide hlist in plainlist in this template isn't an issue, we can use
-- module:list directly
-- [https://en.wikipedia.org/w/index.php?title=Module:Collapsible_list/sandbox&oldid=1130172480]
-- is an implementation (that will code rot slightly I expect)
local function buildList( args )
local function buildList( args )
     -- Get the list items.
     -- Get the list items.
Line 52: Line 57:
     end
     end
     listItems = table.concat( listItems )
     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.
     -- Get class, style and title data.
     local div1class = formatAttributes( 'class', 'NavFrame', not args.expand and 'collapsed' )
     local collapsibleContainerClass = formatAttributes(
     local div1style = formatAttributes(
    'class',
    'collapsible-list',
    'mw-collapsible',
    not args.expand and 'mw-collapsed'
    )
     local collapsibleContainerStyle = formatAttributes(
         'style',
         'style',
        -- mostly work around .infobox-full-data defaulting to centered
        'text-align: left;',
         args.frame_style,
         args.frame_style,
         args.framestyle,
         args.framestyle
        not ( args.frame_style or args.framestyle ) and 'border: none; padding: 0;'
     )
     )
     local div2class = formatAttributes( 'class', 'NavHead' )
     local collapsibleTitleStyle = formatAttributes(
    local div2style = formatAttributes(
         'style',
         'style',
         'font-size: 105%;',
         'line-height: 1.6em; font-weight: bold;',
         args.title_style,
         args.title_style,
         args.titlestyle,
         args.titlestyle
         not ( args.title_style or args.titlestyle ) and 'background: transparent; text-align: left;'
    )
    local jumpyTitleStyle = formatAttributes(
         'style',
        centeredTitleSpacing
     )
     )
     local title = args.title or 'List'
     local title = args.title or 'List'
     local ulclass = formatAttributes( 'class', 'NavContent', args.hlist and 'hlist' )
     local ulclass = formatAttributes( 'class', 'mw-collapsible-content', args.hlist and 'hlist' )
     local ulstyle = formatAttributes(  
     local ulstyle = formatAttributes(  
         'style',
         'style',
         not args.bullets and 'list-style: none none; margin-left: 0;',
        'margin-top: 0; margin-bottom: 0; line-height: inherit;',
         not args.bullets and 'list-style: none; margin-left: 0;',
         args.list_style,
         args.list_style,
         args.liststyle,
         args.liststyle
        not ( args.list_style or args.liststyle ) and 'text-align: left;',
        'font-size: 105%; margin-top: 0; margin-bottom: 0; line-height: inherit;'
     )
     )
   
    local hlist_templatestyles = ''
    if args.hlist then
    hlist_templatestyles = mw.getCurrentFrame():extensionTag{
    name = 'templatestyles', args = { src = 'Hlist/styles.css' }
    }
    end
      
      
     -- Build the list.
     -- Build the list.
     return mw.ustring.format(  
     return mw.ustring.format(  
         '<div%s%s>\n<div%s%s>%s</div>\n<ul%s%s>%s</ul>\n</div>',
         '%s<div%s%s>\n<div%s><div%s>%s</div></div>\n<ul%s%s>%s</ul>\n</div>',
         div1class, div1style, div2class, div2style, title, ulclass, ulstyle, listItems
         hlist_templatestyles, collapsibleContainerClass, collapsibleContainerStyle,
        collapsibleTitleStyle, jumpyTitleStyle, title, ulclass, ulstyle, listItems
     )
     )
end
end

Latest revision as of 02:02, 14 February 2024

Documentation for this module may be created at Module:Collapsible list/doc

local p = {}

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

-- TODO: use Module:List. Since the update for this comment is routine,
-- this is blocked without a consensus discussion by
-- [[MediaWiki_talk:Common.css/Archive_15#plainlist_+_hlist_indentation]]
-- if we decide hlist in plainlist in this template isn't an issue, we can use
-- module:list directly
-- [https://en.wikipedia.org/w/index.php?title=Module:Collapsible_list/sandbox&oldid=1130172480]
-- is an implementation (that will code rot slightly I expect)
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',
    	'collapsible-list',
    	'mw-collapsible',
    	not args.expand and 'mw-collapsed'
    )
    local collapsibleContainerStyle = formatAttributes(
        'style',
         -- mostly work around .infobox-full-data defaulting to centered
        'text-align: left;',
        args.frame_style,
        args.framestyle
    )
    local collapsibleTitleStyle = formatAttributes(
        'style',
        'line-height: 1.6em; font-weight: bold;',
        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',
        'margin-top: 0; margin-bottom: 0; line-height: inherit;',
        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
    )
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