Difference between revisions of "Module:Aligned table"

From annadreambrush.com/wiki
Jump to navigation Jump to search
imported>Frietjes
imported>Alex 21
(Implementing talk page edit requested)
 
(42 intermediate revisions by 5 users not shown)
Line 1: Line 1:
 
-- This module implements {{aligned table}}
 
-- This module implements {{aligned table}}
 +
local p = {}
  
local p = {}
+
local function isnotempty(s)
 +
return s and s:match( '^%s*(.-)%s*$' ) ~= ''
 +
end
  
 
function p.table(frame)
 
function p.table(frame)
Line 9: Line 12:
 
local colstyle = {}
 
local colstyle = {}
 
local cols = tonumber(args['cols']) or 2
 
local cols = tonumber(args['cols']) or 2
local class = args['class'] or ''
+
 
local style = args['style'] or ''
+
-- create the root table
local leftright = args['leftright'] or ''
+
local root = mw.html.create('table')
local fullwidth = args['fullwidth'] or ''
+
 
+
-- add table style for fullwidth
if leftright ~= '' then
+
if isnotempty(args['fullwidth']) then
 +
root
 +
:css('width', '100%')
 +
:css('border-collapse', 'collapse')
 +
:css('border-spacing', '0px 0px')
 +
:css('border', 'none')
 +
end
 +
 
 +
-- add table classes
 +
if isnotempty(args['class']) then
 +
root:addClass(args['class'])
 +
end
 +
 
 +
-- add table style
 +
if isnotempty(args['style']) then
 +
root:cssText(args['style'])
 +
end
 +
 
 +
-- build arrays with the column styles and classes
 +
if isnotempty(args['leftright']) then
 
colstyle[1] = 'text-align:left;'
 
colstyle[1] = 'text-align:left;'
 
colstyle[2] = 'text-align:right;'
 
colstyle[2] = 'text-align:right;'
    end
 
if fullwidth ~= '' then
 
style = 'width:100%; border-collapse: collapse; border-spacing: 0px; border:none;' .. style
 
 
end
 
end
if class ~= '' then
+
if isnotempty(args['rightleft']) then
class = ' class="' .. class .. '"'
+
colstyle[1] = 'text-align:right;'
 +
colstyle[2] = 'text-align:left;'
 
end
 
end
if style ~= '' then
 
style = ' style="' .. style .. '"'
 
end
 
 
 
for i = 1,cols do
 
for i = 1,cols do
 
colclass[ i ] = colclass[ i ] or ''
 
colclass[ i ] = colclass[ i ] or ''
 
colstyle[ i ] = colstyle[ i ] or ''
 
colstyle[ i ] = colstyle[ i ] or ''
if args['align' .. tostring(i)] then
+
if isnotempty(args['colstyle']) then
 +
colstyle[ i ] = args['colstyle'] .. ';' .. colstyle[ i ]
 +
end
 +
if isnotempty(args['colalign' .. tostring(i)]) then
 +
colstyle[ i ] = 'text-align:' .. args['colalign' .. tostring(i)] .. ';' .. colstyle[ i ]
 +
elseif isnotempty(args['col' .. tostring(i) .. 'align']) then
 +
colstyle[ i ] = 'text-align:' .. args['col' .. tostring(i) .. 'align'] .. ';' .. colstyle[ i ]
 +
elseif isnotempty(args['align' .. tostring(i)]) then
 
colstyle[ i ] = 'text-align:' .. args['align' .. tostring(i)] .. ';' .. colstyle[ i ]
 
colstyle[ i ] = 'text-align:' .. args['align' .. tostring(i)] .. ';' .. colstyle[ i ]
 
end
 
end
if args['nowrap' .. tostring(i)] and args['nowrap' .. tostring(i)] ~= '' then
+
if isnotempty(args['colnowrap' .. tostring(i)]) then
 +
colstyle[ i ] = 'white-space:nowrap;' .. colstyle[ i ]
 +
elseif isnotempty(args['col' .. tostring(i) .. 'nowrap']) then
 
colstyle[ i ] = 'white-space:nowrap;' .. colstyle[ i ]
 
colstyle[ i ] = 'white-space:nowrap;' .. colstyle[ i ]
 +
elseif isnotempty(args['nowrap' .. tostring(i)]) then
 +
colstyle[ i ] = 'white-space:nowrap;' .. colstyle[ i ]
 +
end
 +
if isnotempty(args['colwidth' .. tostring(i)]) then
 +
colstyle[ i ] = 'width:' .. args['colwidth' .. tostring(i)] .. ';' .. colstyle[ i ]
 +
elseif isnotempty(args['col' .. tostring(i) .. 'width']) then
 +
colstyle[ i ] = 'width:' .. args['col' .. tostring(i) .. 'width'] .. ';' .. colstyle[ i ]
 +
elseif isnotempty(args['colwidth']) then
 +
colstyle[ i ] = 'width:' .. args['colwidth'] .. ';' .. colstyle[ i ]
 
end
 
end
if args['style' .. tostring(i)] then
+
if isnotempty(args['colstyle' .. tostring(i)]) then
 +
colstyle[ i ] = colstyle[ i ] .. args['colstyle' .. tostring(i)]
 +
elseif isnotempty(args['col' .. tostring(i) .. 'style']) then
 +
colstyle[ i ] = colstyle[ i ] .. args['col' .. tostring(i) .. 'style']
 +
elseif isnotempty(args['style' .. tostring(i)]) then
 
colstyle[ i ] = colstyle[ i ] .. args['style' .. tostring(i)]
 
colstyle[ i ] = colstyle[ i ] .. args['style' .. tostring(i)]
 
end
 
end
if args['class' .. tostring(i)] then
+
if isnotempty(args['colclass' .. tostring(i)]) then
 +
colclass[ i ] =  args['colclass' .. tostring(i)]
 +
elseif isnotempty(args['col' .. tostring(i) .. 'class']) then
 +
colclass[ i ] =  args['col' .. tostring(i) .. 'class']
 +
elseif isnotempty(args['class' .. tostring(i)]) then
 
colclass[ i ] =  args['class' .. tostring(i)]
 
colclass[ i ] =  args['class' .. tostring(i)]
 
end
 
end
 
end
 
end
+
-- compute the maximum cell index
 +
local cellcount = 0
 
for k, v in pairs( args ) do
 
for k, v in pairs( args ) do
 
if type( k ) == 'number' then
 
if type( k ) == 'number' then
i = math.fmod(k-1,cols) + 1
+
cellcount = math.max(cellcount, k)
entries[ k ] = '<td class="' .. colclass[i] .. '" style="' .. colstyle[i] .. '">' .. v .. '</td>'
+
end
if i == 1 then
+
end
entries[ k ] = '<tr style="vertical-align:top">' .. entries[ k ]
+
-- compute the number of rows
 +
local rows = math.ceil(cellcount / cols)
 +
 
 +
-- build the table content
 +
if isnotempty(args['title']) then
 +
local caption = root:tag('caption')
 +
caption:cssText(args['titlestyle'])
 +
caption:wikitext(args['title'])
 +
end
 +
if isnotempty(args['above']) then
 +
local row = root:tag('tr')
 +
local cell = row:tag('th')
 +
cell:attr('colspan', cols)
 +
cell:cssText(args['abovestyle'])
 +
cell:wikitext(args['above'])
 +
end
 +
for j=1,rows do
 +
-- start a new row
 +
local row = root:tag('tr')
 +
if isnotempty(args['rowstyle']) then
 +
row:cssText(args['rowstyle'])
 +
else
 +
row:css('vertical-align', 'top')
 +
end
 +
-- loop over the cells in the row
 +
for i=1,cols do
 +
local cell
 +
if isnotempty(args['row' .. tostring(j) .. 'header']) then
 +
cell = row:tag('th'):attr('scope','col')
 +
elseif isnotempty(args['col' .. tostring(i) .. 'header']) then
 +
cell = row:tag('th'):attr('scope','row')
 +
else
 +
cell = row:tag('td')
 +
end
 +
if args['class' .. tostring(j) .. '.' .. tostring(i)] then
 +
cell:addClass(args['class' .. tostring(j) .. '.' .. tostring(i)])
 +
else
 +
if args['rowclass' .. tostring(j)] then
 +
cell:addClass(args['rowclass' .. tostring(j)])
 +
elseif args['row' .. tostring(j) .. 'class'] then
 +
cell:addClass(args['row' .. tostring(j) .. 'class'])
 +
elseif args['rowevenclass'] and math.fmod(j,2) == 0 then
 +
cell:addClass(args['rowevenclass'])
 +
elseif args['rowoddclass'] and math.fmod(j,2) == 1 then
 +
cell:addClass(args['rowoddclass'])
 +
end
 +
if colclass[i] ~= '' then
 +
cell:addClass(colclass[i])
 +
end
 
end
 
end
if i == cols then
+
if args['style' .. tostring(j) .. '.' .. tostring(i)] then
entries[ k ] = entries[k] .. '</tr>'
+
cell:cssText(args['style' .. tostring(j) .. '.' .. tostring(i)])
 +
else
 +
if args['rowstyle' .. tostring(j)] then
 +
cell:cssText(args['rowstyle' .. tostring(j)])
 +
elseif args['rowevenstyle'] and math.fmod(j,2) == 0 then
 +
cell:cssText(args['rowevenstyle'])
 +
elseif args['rowoddstyle'] and math.fmod(j,2) == 1 then
 +
cell:cssText(args['rowoddstyle'])
 +
elseif args['row' .. tostring(j) .. 'style'] then
 +
cell:cssText(args['row' .. tostring(j) .. 'style'])
 +
end
 +
if isnotempty(colstyle[i]) then
 +
cell:cssText(colstyle[i])
 +
end
 
end
 
end
        end
+
cell:wikitext(mw.ustring.gsub(args[cols*(j - 1) + i] or '', '^(.-)%s*$', '%1') or '')
    end
+
end
    return '<table' .. class .. style ..'>\n' .. table.concat( entries, '\n' ) .. '\n</table>'
+
end
   
+
-- return the root table
end
+
return tostring(root)
 +
end
  
 
return p
 
return p

Latest revision as of 08:13, 22 March 2019

Documentation for this module may be created at Module:Aligned table/doc

-- This module implements {{aligned table}}
local p = {}

local function isnotempty(s)
	return s and s:match( '^%s*(.-)%s*$' ) ~= ''
end

function p.table(frame)
	local args = (frame.args[3] ~= nil) and frame.args or frame:getParent().args
	local entries = {}
	local colclass = {}
	local colstyle = {}
	local cols = tonumber(args['cols']) or 2

	-- create the root table
	local root = mw.html.create('table')

	-- add table style for fullwidth
	if isnotempty(args['fullwidth']) then
		root
			:css('width', '100%')
			:css('border-collapse', 'collapse')
			:css('border-spacing', '0px 0px')
			:css('border', 'none')
	end

	-- add table classes
	if isnotempty(args['class']) then
		root:addClass(args['class'])
	end

	-- add table style
	if isnotempty(args['style']) then
		root:cssText(args['style'])
	end

	-- build arrays with the column styles and classes
	if isnotempty(args['leftright']) then
		colstyle[1] = 'text-align:left;'
		colstyle[2] = 'text-align:right;'
	end
	if isnotempty(args['rightleft']) then
		colstyle[1] = 'text-align:right;'
		colstyle[2] = 'text-align:left;'
	end
	for i = 1,cols do
		colclass[ i ] = colclass[ i ] or ''
		colstyle[ i ] = colstyle[ i ] or ''
		if isnotempty(args['colstyle']) then
			colstyle[ i ] = args['colstyle'] .. ';' .. colstyle[ i ]
		end
		if isnotempty(args['colalign' .. tostring(i)]) then
			colstyle[ i ] = 'text-align:' .. args['colalign' .. tostring(i)] .. ';' .. colstyle[ i ]
		elseif isnotempty(args['col' .. tostring(i) .. 'align']) then
			colstyle[ i ] = 'text-align:' .. args['col' .. tostring(i) .. 'align'] .. ';' .. colstyle[ i ]
		elseif isnotempty(args['align' .. tostring(i)]) then
			colstyle[ i ] = 'text-align:' .. args['align' .. tostring(i)] .. ';' .. colstyle[ i ]
		end
		if isnotempty(args['colnowrap' .. tostring(i)]) then
			colstyle[ i ] = 'white-space:nowrap;' .. colstyle[ i ]
		elseif isnotempty(args['col' .. tostring(i) .. 'nowrap']) then
			colstyle[ i ] = 'white-space:nowrap;' .. colstyle[ i ]
		elseif isnotempty(args['nowrap' .. tostring(i)]) then
			colstyle[ i ] = 'white-space:nowrap;' .. colstyle[ i ]
		end
		if isnotempty(args['colwidth' .. tostring(i)]) then
			colstyle[ i ] = 'width:' .. args['colwidth' .. tostring(i)] .. ';' .. colstyle[ i ]
		elseif isnotempty(args['col' .. tostring(i) .. 'width']) then
			colstyle[ i ] = 'width:' .. args['col' .. tostring(i) .. 'width'] .. ';' .. colstyle[ i ]
		elseif isnotempty(args['colwidth']) then
			colstyle[ i ] = 'width:' .. args['colwidth'] .. ';' .. colstyle[ i ]
		end
		if isnotempty(args['colstyle' .. tostring(i)]) then
			colstyle[ i ] = colstyle[ i ] .. args['colstyle' .. tostring(i)]
		elseif isnotempty(args['col' .. tostring(i) .. 'style']) then
			colstyle[ i ] = colstyle[ i ] .. args['col' .. tostring(i) .. 'style']
		elseif isnotempty(args['style' .. tostring(i)]) then
			colstyle[ i ] = colstyle[ i ] .. args['style' .. tostring(i)]
		end
		if isnotempty(args['colclass' .. tostring(i)]) then
			colclass[ i ] =  args['colclass' .. tostring(i)]
		elseif isnotempty(args['col' .. tostring(i) .. 'class']) then
			colclass[ i ] =  args['col' .. tostring(i) .. 'class']
		elseif isnotempty(args['class' .. tostring(i)]) then
			colclass[ i ] =  args['class' .. tostring(i)]
		end
	end
	-- compute the maximum cell index
	local cellcount = 0
	for k, v in pairs( args ) do
		if type( k ) == 'number' then
			cellcount = math.max(cellcount, k)
		end
	end
	-- compute the number of rows
	local rows = math.ceil(cellcount / cols)

	-- build the table content
	if isnotempty(args['title']) then
		local caption = root:tag('caption')
		caption:cssText(args['titlestyle'])
		caption:wikitext(args['title'])
	end
	if isnotempty(args['above']) then
		local row = root:tag('tr')
		local cell = row:tag('th')
		cell:attr('colspan', cols)
		cell:cssText(args['abovestyle'])
		cell:wikitext(args['above'])
	end
	for j=1,rows do
		-- start a new row
		local row = root:tag('tr')
		if isnotempty(args['rowstyle']) then
			row:cssText(args['rowstyle'])
		else
			row:css('vertical-align', 'top')
		end
		-- loop over the cells in the row
		for i=1,cols do
			local cell
			if isnotempty(args['row' .. tostring(j) .. 'header']) then
				cell = row:tag('th'):attr('scope','col')
			elseif isnotempty(args['col' .. tostring(i) .. 'header']) then
				cell = row:tag('th'):attr('scope','row')
			else
				cell = row:tag('td')
			end
			if args['class' .. tostring(j) .. '.' .. tostring(i)] then
				cell:addClass(args['class' .. tostring(j) .. '.' .. tostring(i)])
			else
				if args['rowclass' .. tostring(j)] then
					cell:addClass(args['rowclass' .. tostring(j)])
				elseif args['row' .. tostring(j) .. 'class'] then
					cell:addClass(args['row' .. tostring(j) .. 'class'])
				elseif args['rowevenclass'] and math.fmod(j,2) == 0 then
					cell:addClass(args['rowevenclass'])
				elseif args['rowoddclass'] and math.fmod(j,2) == 1 then	
					cell:addClass(args['rowoddclass'])
				end
				if colclass[i] ~= '' then
					cell:addClass(colclass[i])
				end
			end
			if args['style' .. tostring(j) .. '.' .. tostring(i)] then
				cell:cssText(args['style' .. tostring(j) .. '.' .. tostring(i)])
			else
				if args['rowstyle' .. tostring(j)] then
					cell:cssText(args['rowstyle' .. tostring(j)])
				elseif args['rowevenstyle'] and math.fmod(j,2) == 0 then
					cell:cssText(args['rowevenstyle'])
				elseif args['rowoddstyle'] and math.fmod(j,2) == 1 then	
					cell:cssText(args['rowoddstyle'])
				elseif args['row' .. tostring(j) .. 'style'] then
					cell:cssText(args['row' .. tostring(j) .. 'style'])
				end
				if isnotempty(colstyle[i]) then
					cell:cssText(colstyle[i])
				end
			end
			cell:wikitext(mw.ustring.gsub(args[cols*(j - 1) + i] or '', '^(.-)%s*$', '%1') or '')
		end
	end
	-- return the root table
	return tostring(root)
end

return p