Difference between revisions of "Module:Gallery"

From Eat Every Plant
Jump to navigation Jump to search
m (1 revision)
 
m (1 revision: Nepenthes)
 
(One intermediate revision by the same user not shown)
Line 27: Line 27:
 
end
 
end
  
local tbl = mw.html.create('table')
+
local tbl = mw.html.create('div'):css('display', 'table')
 
      
 
      
 
if args.state then
 
if args.state then
Line 56: Line 56:
 
if args.title then
 
if args.title then
 
tbl
 
tbl
:tag('tr')
+
:tag('div'):css('display', 'table-row')
:tag('th')
+
:tag('div'):css('display', 'table-cell')
 
:css('text-align', 'center')
 
:css('text-align', 'center')
 
:css('font-weight', 'bold')
 
:css('font-weight', 'bold')
Line 63: Line 63:
 
end
 
end
 
 
local mainCell = tbl:tag('tr'):tag('td')
+
local mainCell = tbl:tag('div'):css('display', 'table-row'):tag('div'):css('display', 'table-cell')
 
 
 
local imageCount = math.ceil(#args / 2)
 
local imageCount = math.ceil(#args / 2)
Line 85: Line 85:
  
 
if img ~= '' then
 
if img ~= '' then
local imgTbl = mainCell:tag('table')
+
local imgTbl = mainCell:tag('div'):css('display', 'table')
 
              
 
              
 
imgTbl
 
imgTbl
Line 92: Line 92:
 
:css('border-collapse', 'collapse')
 
:css('border-collapse', 'collapse')
 
:css('margin', '3px')
 
:css('margin', '3px')
:tag('tr')
+
:tag('div'):css('display', 'table-row')
:tag('td')
+
:tag('div'):css('display', 'table-cell')
 
:css('height', (imgHeight + 20) .. 'px')
 
:css('height', (imgHeight + 20) .. 'px')
 
:css('border', '1px solid #CCCCCC')
 
:css('border', '1px solid #CCCCCC')
Line 102: Line 102:
 
:done()
 
:done()
 
:done()
 
:done()
:tag('tr')
+
:tag('div'):css('display', 'table-row')
 
:css('vertical-align', 'top')
 
:css('vertical-align', 'top')
:tag('td')
+
:tag('div'):css('display', 'table-cell')
 
:css('display', 'block')
 
:css('display', 'block')
:css('font-size', '1em')
+
:css('font-size', '94%')
 
:css('padding', '0px')
 
:css('padding', '0px')
 
:tag('div')
 
:tag('div')
Line 124: Line 124:
 
if args.footer then
 
if args.footer then
 
tbl
 
tbl
:tag('tr')
+
:tag('div'):css('display', 'table-row')
:tag('td')
+
:tag('div'):css('display', 'table-cell')
 
:css('text-align', 'right')
 
:css('text-align', 'right')
 
:css('font-size', '80%')
 
:css('font-size', '80%')

Latest revision as of 00:37, 28 May 2018

-- This module implements

local p = {}

local function trim(s) return (mw.ustring.gsub(s, "^%s*(.-)%s*$", "%1")) end

function p.gallery(frame) local origArgs -- If called via #invoke, use the args passed into the invoking template. -- Otherwise, for testing purposes, assume args are being passed directly in. if type(frame.getParent) == 'function' then origArgs = frame:getParent().args else origArgs = frame end

   -- ParserFunctions considers the empty string to be false, so to preserve the previous 

-- behavior of

, change any empty arguments to nil, so Lua will consider

   -- them false too.
   local args = {}
   for k, v in pairs(origArgs) do
   	if v ~=  then
   		args[k] = v
   	end

end

local tbl = mw.html.create('div'):css('display', 'table')

if args.state then tbl :css('width', '100%') :addClass('collapsible') :addClass(args.state) end

if args.style then tbl:cssText(args.style) else tbl :css('background', 'transparent') :css('margin-top', '0.5em') end

if args.align then if args.align == 'center' then tbl :css('margin-left', 'auto') :css('margin-right', 'auto') else tbl:css('float', args.align) end end

if args.title then tbl :tag('div'):css('display', 'table-row') :tag('div'):css('display', 'table-cell') :css('text-align', 'center') :css('font-weight', 'bold') :wikitext(args.title) end

local mainCell = tbl:tag('div'):css('display', 'table-row'):tag('div'):css('display', 'table-cell')

local imageCount = math.ceil(#args / 2) local cellWidth = tonumber(args.cellwidth) or tonumber(args.width) or 180 local imgHeight = tonumber(args.height) or 180 local lines = tonumber(args.lines) or 2 local captionstyle = args.captionstyle

   for i = 1, imageCount do

local img = trim(args[i*2 - 1] or ) local caption = trim(args[i*2] or ) local imgWidth = tonumber(args['width' .. i]) or tonumber(args.width) or 180 local alt = args['alt' .. i] or

local textWidth if cellWidth < 30 then textWidth = imgHeight + 27 else textWidth = cellWidth + 7 end

if img ~= then local imgTbl = mainCell:tag('div'):css('display', 'table')

imgTbl :css('width', (cellWidth + 20) .. 'px') :css('float', 'left') :css('border-collapse', 'collapse') :css('margin', '3px') :tag('div'):css('display', 'table-row') :tag('div'):css('display', 'table-cell') :css('height', (imgHeight + 20) .. 'px') :css('border', '1px solid #CCCCCC') :css('background-color', '#F8F8F8') :css('padding', '0px') :css('text-align', 'center') :wikitext(string.format('center|border|%dx%dpx|alt=%s|%s', img, imgWidth, imgHeight, alt, mw.text.unstrip(caption))) :done() :done() :tag('div'):css('display', 'table-row') :css('vertical-align', 'top') :tag('div'):css('display', 'table-cell') :css('display', 'block') :css('font-size', '94%') :css('padding', '0px') :tag('div') :addClass('gallerytext') :css('min-height', (0.1 + 1.5*lines) .. 'em') :css('width', textWidth .. 'px') :css('line-height', '1.3em') :css('padding', '2px 6px 1px 6px') :css('margin', '0px') :css('border', 'none') :css('border-width', '0px') :cssText(captionstyle) :wikitext(caption .. ' ') end end

if args.footer then tbl :tag('div'):css('display', 'table-row') :tag('div'):css('display', 'table-cell') :css('text-align', 'right') :css('font-size', '80%') :css('line-height', '1em') :wikitext(args.footer) end if args.perrow then tbl:css('width', 8 + (cellWidth + 20 + 6)*tonumber(args.perrow) .. 'px') end

return tostring(tbl) end

return p