<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://linguifex.com/w/index.php?action=history&amp;feed=atom&amp;title=Module%3AColumns</id>
	<title>Module:Columns - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://linguifex.com/w/index.php?action=history&amp;feed=atom&amp;title=Module%3AColumns"/>
	<link rel="alternate" type="text/html" href="https://linguifex.com/w/index.php?title=Module:Columns&amp;action=history"/>
	<updated>2026-04-06T17:54:41Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.43.6</generator>
	<entry>
		<id>https://linguifex.com/w/index.php?title=Module:Columns&amp;diff=214835&amp;oldid=prev</id>
		<title>Chrysophylax: Created page with &quot;local export = {}  local m_links = require(&quot;Module:links&quot;) local m_languages = require(&quot;Module:languages&quot;)   local function format_list_items(items, lang) 	local result = {}...&quot;</title>
		<link rel="alternate" type="text/html" href="https://linguifex.com/w/index.php?title=Module:Columns&amp;diff=214835&amp;oldid=prev"/>
		<updated>2021-01-02T04:24:01Z</updated>

		<summary type="html">&lt;p&gt;Created page with &amp;quot;local export = {}  local m_links = require(&amp;quot;Module:links&amp;quot;) local m_languages = require(&amp;quot;Module:languages&amp;quot;)   local function format_list_items(items, lang) 	local result = {}...&amp;quot;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;local export = {}&lt;br /&gt;
&lt;br /&gt;
local m_links = require(&amp;quot;Module:links&amp;quot;)&lt;br /&gt;
local m_languages = require(&amp;quot;Module:languages&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
local function format_list_items(items, lang)&lt;br /&gt;
	local result = {}&lt;br /&gt;
	&lt;br /&gt;
	for i, item in ipairs(items) do&lt;br /&gt;
		if lang and not string.find(item, &amp;quot;&amp;lt;span&amp;quot;) then&lt;br /&gt;
			item = m_links.full_link({lang = lang, term = item})&lt;br /&gt;
		end&lt;br /&gt;
		&lt;br /&gt;
		result[i] = &amp;#039;\n* &amp;#039; .. item&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return table.concat(result)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
local collapse_header =&lt;br /&gt;
	[[&amp;lt;div class=&amp;quot;list-switcher&amp;quot; data-toggle-category=&amp;quot;{{{toggle_category}}}&amp;quot;&amp;gt;]]&lt;br /&gt;
local column_header = [[&amp;lt;div class=&amp;quot;{{{class}}} term-list ul-column-count&amp;quot; ]]&lt;br /&gt;
	.. [[data-column-count=&amp;quot;{{{column_count}}}&amp;quot; ]]&lt;br /&gt;
	.. [[style=&amp;quot;background-color: {{{background_color}}};&amp;quot;&amp;gt;]]&lt;br /&gt;
local button = [[&amp;lt;div class=&amp;quot;list-switcher-element&amp;quot; ]]&lt;br /&gt;
	.. [[data-showtext=&amp;quot;&amp;amp;nbsp;show more ▼&amp;amp;nbsp;&amp;quot; ]]&lt;br /&gt;
	.. [[data-hidetext=&amp;quot;&amp;amp;nbsp;show less ▲&amp;amp;nbsp;&amp;quot; style=&amp;quot;display: none;&amp;quot;&amp;gt;&amp;amp;nbsp;&amp;lt;/div&amp;gt;]]&lt;br /&gt;
&lt;br /&gt;
function export.create_list(args)&lt;br /&gt;
	-- Fields in args that are used:&lt;br /&gt;
	-- args.column_count, args.content, args.alphabetize, args.background_color,&lt;br /&gt;
	-- args.collapse, args.toggle_category, args.class, args.lang&lt;br /&gt;
	-- Check for required fields?&lt;br /&gt;
	if type(args) ~= &amp;quot;table&amp;quot; then&lt;br /&gt;
		error(&amp;quot;expected table, got &amp;quot; .. type(args))&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	args.class = args.class or &amp;quot;derivedterms&amp;quot;&lt;br /&gt;
	args.column_count = args.column_count or 1&lt;br /&gt;
	args.toggle_category = args.toggle_category or &amp;quot;derived terms&amp;quot;&lt;br /&gt;
	&lt;br /&gt;
	local output = {}&lt;br /&gt;
	&lt;br /&gt;
	if args.header then&lt;br /&gt;
		if args.format_header then&lt;br /&gt;
			args.header = &amp;#039;&amp;lt;div class=&amp;quot;term-list-header&amp;quot;&amp;gt;&amp;#039; .. args.header .. &amp;quot;&amp;lt;/div&amp;gt;&amp;quot;&lt;br /&gt;
		end&lt;br /&gt;
		table.insert(output, args.header)&lt;br /&gt;
	end&lt;br /&gt;
	if args.collapse then&lt;br /&gt;
		table.insert(output, (collapse_header:gsub(&amp;#039;{{{(.-)}}}&amp;#039;, args)))&lt;br /&gt;
	end&lt;br /&gt;
	table.insert(output, (column_header:gsub(&amp;#039;{{{(.-)}}}&amp;#039;, args)))&lt;br /&gt;
	&lt;br /&gt;
    if args.alphabetize then&lt;br /&gt;
		require(&amp;quot;Module:collation&amp;quot;).sort(args.content, args.lang)&lt;br /&gt;
	end&lt;br /&gt;
	table.insert(output, format_list_items(args.content, args.lang))&lt;br /&gt;
	&lt;br /&gt;
	table.insert(output, &amp;#039;&amp;lt;/div&amp;gt;&amp;#039;)&lt;br /&gt;
	if args.collapse then&lt;br /&gt;
		table.insert(output, button .. &amp;#039;&amp;lt;/div&amp;gt;&amp;#039;)&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return table.concat(output)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
-- This function is for compatibility with earlier version of [[Module:columns]]&lt;br /&gt;
-- (now found in [[Module:columns/old]]).&lt;br /&gt;
function export.create_table(...)&lt;br /&gt;
	-- Earlier arguments to create_table:&lt;br /&gt;
	-- n_columns, content, alphabetize, bg, collapse, class, title, column_width, line_start, lang&lt;br /&gt;
	local args = {}&lt;br /&gt;
	args.column_count, args.content, args.alphabetize, args.background_color,&lt;br /&gt;
		args.collapse, args.class, args.header, args.column_width,&lt;br /&gt;
		args.line_start, args.lang = ...&lt;br /&gt;
	&lt;br /&gt;
	args.format_header = true&lt;br /&gt;
	&lt;br /&gt;
	return export.create_list(args)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
function export.display(frame)&lt;br /&gt;
	local iparams = {&lt;br /&gt;
		[&amp;quot;class&amp;quot;] = {},&lt;br /&gt;
		-- Default for auto-collapse. Overridable by template |collapse= param.&lt;br /&gt;
		[&amp;quot;collapse&amp;quot;] = {type = &amp;quot;boolean&amp;quot;},&lt;br /&gt;
		-- If specified, this specifies the number of columns, and no columns&lt;br /&gt;
		-- parameter is available on the template. Otherwise, the columns&lt;br /&gt;
		-- parameter is the first available numbered param after the language-code&lt;br /&gt;
		-- parameter.&lt;br /&gt;
		[&amp;quot;columns&amp;quot;] = {type = &amp;quot;number&amp;quot;},&lt;br /&gt;
		-- If specified, this specifies the language code, and no language-code&lt;br /&gt;
		-- parameter is available on the template. Otherwise, the language-code&lt;br /&gt;
		-- parameter can be specified as either |lang= or |1=.&lt;br /&gt;
		[&amp;quot;lang&amp;quot;] = {},&lt;br /&gt;
		-- Default for auto-sort. Overridable by template |sort= param.&lt;br /&gt;
		[&amp;quot;sort&amp;quot;] = {type = &amp;quot;boolean&amp;quot;},&lt;br /&gt;
		-- The following is accepted but currently ignored, per an extended discussion in&lt;br /&gt;
		-- [[Wiktionary:Beer parlour/2018/November#Titles of morphological relations templates]].&lt;br /&gt;
		[&amp;quot;title&amp;quot;] = {default = &amp;quot;&amp;quot;},&lt;br /&gt;
		[&amp;quot;toggle_category&amp;quot;] = {},&lt;br /&gt;
	}&lt;br /&gt;
	&lt;br /&gt;
	local frame_args = require(&amp;quot;Module:parameters&amp;quot;).process(frame.args, iparams)&lt;br /&gt;
	local parent_args = frame:getParent().args&lt;br /&gt;
	&lt;br /&gt;
	local compat = frame_args[&amp;quot;lang&amp;quot;] or parent_args[&amp;quot;lang&amp;quot;]&lt;br /&gt;
	local lang_param = compat and &amp;quot;lang&amp;quot; or 1&lt;br /&gt;
	local columns_param = compat and 1 or 2&lt;br /&gt;
	local first_content_param = columns_param + (frame_args[&amp;quot;columns&amp;quot;] and 0 or 1)&lt;br /&gt;
&lt;br /&gt;
	local params = {&lt;br /&gt;
		[lang_param] = not frame_args[&amp;quot;lang&amp;quot;] and {required = true, default = &amp;quot;und&amp;quot;} or nil,&lt;br /&gt;
		[columns_param] = not frame_args[&amp;quot;columns&amp;quot;] and {required = true, default = 2} or nil,&lt;br /&gt;
		[first_content_param] = {list = true},&lt;br /&gt;
		&lt;br /&gt;
		[&amp;quot;title&amp;quot;] = {},&lt;br /&gt;
		[&amp;quot;collapse&amp;quot;] = {type = &amp;quot;boolean&amp;quot;},&lt;br /&gt;
		[&amp;quot;sort&amp;quot;] = {type = &amp;quot;boolean&amp;quot;},&lt;br /&gt;
	}&lt;br /&gt;
	&lt;br /&gt;
	local args = require(&amp;quot;Module:parameters&amp;quot;).process(parent_args, params)&lt;br /&gt;
	&lt;br /&gt;
	local lang = frame_args[&amp;quot;lang&amp;quot;] or args[lang_param]&lt;br /&gt;
	lang = m_languages.getByCode(lang) or m_languages.err(lang, lang_param)&lt;br /&gt;
	&lt;br /&gt;
	local sort = frame_args[&amp;quot;sort&amp;quot;]&lt;br /&gt;
	if args[&amp;quot;sort&amp;quot;] ~= nil then&lt;br /&gt;
		sort = args[&amp;quot;sort&amp;quot;]&lt;br /&gt;
	end&lt;br /&gt;
	local collapse = frame_args[&amp;quot;collapse&amp;quot;]&lt;br /&gt;
	if args[&amp;quot;collapse&amp;quot;] ~= nil then&lt;br /&gt;
		collapse = args[&amp;quot;collapse&amp;quot;]&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	return export.create_list { column_count = frame_args[&amp;quot;columns&amp;quot;] or args[columns_param],&lt;br /&gt;
		content = args[first_content_param],&lt;br /&gt;
		alphabetize = sort,&lt;br /&gt;
		header = args[&amp;quot;title&amp;quot;], background_color = &amp;quot;#F8F8FF&amp;quot;,&lt;br /&gt;
		collapse = collapse,&lt;br /&gt;
		toggle_category = frame_args[&amp;quot;toggle_category&amp;quot;],&lt;br /&gt;
		class = frame_args[&amp;quot;class&amp;quot;], lang = lang, format_header = true }&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
return export&lt;/div&gt;</summary>
		<author><name>Chrysophylax</name></author>
	</entry>
</feed>