Modul:Multiple image: Forskjell mellom sideversjoner
Hopp til navigering
Hopp til søk
m (Én sideversjon ble importert) |
(norsk fra sandkasse) |
||
Linje 1: | Linje 1: | ||
-- implements [[template:multiple |
-- implements [[template:multiple image]] |
||
local p = {} |
local p = {} |
||
local autoscaledimages |
|||
local nonautoscaledimages |
|||
local function isnotempty(s) |
local function isnotempty(s) |
||
Linje 6: | Linje 9: | ||
end |
end |
||
local function removepx(s) |
|||
local function renderbildeCell(bilde, width, height, link, alt, caption, textalign, istyle) |
|||
return tostring(s or ''):match('^(.*)[Pp][Xx]%s*$') or s |
|||
end |
|||
local function getdimensions(s, w, h) |
|||
if tonumber(w) and tonumber(h) then |
|||
nonautoscaledimages = true |
|||
return tonumber(w), tonumber(h) |
|||
end |
|||
local file = s and mw.title.new('File:' .. mw.uri.decode(mw.ustring.gsub(s,'%|.*$',''), 'WIKI')) |
|||
file = file and file.file or {width = 0, height = 0} |
|||
w = tonumber(file.width) or 0 |
|||
h = tonumber(file.height) or 0 |
|||
autoscaledimages = true |
|||
return w, h |
|||
end |
|||
local function renderImageCell(image, width, height, link, alt, thumbtime, caption, class, textalign, istyle, border) |
|||
local root = mw.html.create('') |
local root = mw.html.create('') |
||
local altstr = '|alt=' .. (alt or '') |
local altstr = '|alt=' .. (alt or '') |
||
local classstr = class and ('|class=' .. class) or '' |
|||
local linkstr = link and ('|link=' .. link) or '' |
local linkstr = link and ('|link=' .. link) or '' |
||
local widthstr = '|' .. tostring(width) .. 'px' |
local widthstr = '|' .. tostring(width) .. 'px' |
||
local thumbtimestr = '' |
|||
local bildediv = root:tag('div') |
|||
if widthstr == '|-nanpx' then |
|||
bildediv:addClass('thumbbilde') |
|||
widthstr = '' |
|||
bildediv:cssText(istyle) |
|||
end |
|||
if isnotempty( thumbtime ) then |
|||
thumbtimestr = '|thumbtime=' .. thumbtime |
|||
end |
|||
local imagediv = root:tag('div') |
|||
imagediv:addClass((border ~= 'infobox') and 'thumbimage' or nil) |
|||
imagediv:cssText(istyle) |
|||
if( height ) then |
if( height ) then |
||
imagediv:css('height', tostring(height) .. 'px') |
|||
imagediv:css('overflow', 'hidden') |
|||
end |
end |
||
imagediv:wikitext('[[file:' .. image .. classstr .. widthstr .. linkstr .. altstr .. thumbtimestr .. ']]') |
|||
if isnotempty(caption) then |
if isnotempty(caption) then |
||
local captiondiv = root:tag('div') |
local captiondiv = root:tag('div') |
||
captiondiv:addClass('thumbcaption') |
captiondiv:addClass((border ~= 'infobox') and 'thumbcaption' or nil) |
||
captiondiv:css('clear', 'left') |
|||
if isnotempty(textalign) then |
if isnotempty(textalign) then |
||
captiondiv: |
captiondiv:addClass('text-align-' .. textalign) |
||
end |
end |
||
captiondiv:wikitext(caption) |
captiondiv:wikitext(caption) |
||
Linje 59: | Linje 87: | ||
ic = ic - thisrow |
ic = ic - thisrow |
||
r = r + 1 |
r = r + 1 |
||
-- use the previous if the next is missing and |
-- use the previous if the next is missing and |
||
-- make sure we don't overstep the number of |
-- make sure we don't overstep the number of images |
||
thisrow = math.min(tonumber(pr[r] or thisrow) or ic, ic) |
thisrow = math.min(tonumber(pr[r] or thisrow) or ic, ic) |
||
end |
end |
||
Linje 66: | Linje 94: | ||
end |
end |
||
local function |
local function renderMultipleImages(frame) |
||
local pargs = frame:getParent().args |
local pargs = frame:getParent().args |
||
local args = frame.args |
local args = frame.args |
||
local width = pargs['width'] or pargs['bredde'] or '' |
local width = removepx(pargs['width']) or removepx(pargs['bredde']) or '' |
||
local dir = pargs['direction'] or pargs['retning'] or '' |
local dir = pargs['direction'] or pargs['retning'] or '' |
||
local |
local border = pargs['border'] or args['border'] or '' |
||
local |
local align = pargs['align'] or args['align'] or pargs['justering'] or args['justering'] or (border == 'infobox' and 'center' or '') |
||
local |
local capalign = pargs['caption_align'] or args['caption_align'] or pargs['justering_undertekst'] or args['justering_undertekst'] or '' |
||
local |
local totalwidth = removepx(pargs['total_width']) or removepx(args['total_width']) or removepx(pargs['totalbredde']) or removepx(args['totalbredde']) or '' |
||
local imgstyle = pargs['image_style'] or args['image_style'] or pargs['bildestil'] or args['bildestil'] |
|||
local header = pargs['header'] or pargs['title'] or pargs['overskrift'] or pargs['tittel'] or '' |
local header = pargs['header'] or pargs['title'] or pargs['overskrift'] or pargs['tittel'] or '' |
||
local footer = pargs['footer'] or pargs['undertekst'] or '' |
local footer = pargs['footer'] or pargs['undertekst'] or '' |
||
local imagegap = tonumber(pargs['image_gap'] or '1') or 1 |
|||
local perrow = nil |
local perrow = nil |
||
local thumbclass = { |
local thumbclass = { |
||
Linje 90: | Linje 120: | ||
} |
} |
||
-- find all the nonempty |
-- find all the nonempty images |
||
local |
local imagenumbers = {} |
||
local |
local imagecount = 0 |
||
for k, v in pairs( pargs ) do |
for k, v in pairs( pargs ) do |
||
-- matches imageX and bildeX |
|||
local i = tonumber(tostring(k):match( '^%s*bilde([%d]+)%s*$' ) or '0') |
|||
local i = tonumber(tostring(k):match( '^%s*b?i[ml][ad]g?e([%d]+)%s*$' ) or '0') |
|||
if( i > 0 and isnotempty(v) ) then |
if( i > 0 and isnotempty(v) ) then |
||
table.insert( |
table.insert( imagenumbers, i) |
||
imagecount = imagecount + 1 |
|||
end |
end |
||
end |
end |
||
-- sort the |
-- sort the imagenumbers |
||
table.sort( |
table.sort(imagenumbers) |
||
-- create an array with the number of |
-- create an array with the number of images per row |
||
perrow = getPerRow(dir == 'vertikal' and '1' or pargs['perrad'], |
perrow = getPerRow((dir == 'vertical' or dir == 'vertikal') and '1' or pargs['perrow'] or pargs['perrad'], imagecount) |
||
-- compute the number of rows |
-- compute the number of rows |
||
local rowcount = #perrow |
local rowcount = #perrow |
||
-- store the |
-- store the image widths and compute row widths and maximum row width |
||
local heights = {} |
|||
local widths = {} |
local widths = {} |
||
local widthmax = 0 |
local widthmax = 0 |
||
Linje 119: | Linje 151: | ||
for c=1,perrow[r] do |
for c=1,perrow[r] do |
||
k = k + 1 |
k = k + 1 |
||
if( k <= |
if( k <= imagecount ) then |
||
local i = |
local i = imagenumbers[k] |
||
if( isnotempty(totalwidth) ) then |
|||
widths[k] = getWidth(width, pargs['bredde' .. i]) |
|||
widths[k], heights[k] = getdimensions(pargs['image' .. i] or pargs['bilde' .. i], pargs['width' .. i] or pargs['bredde' .. i], pargs['height' .. i] or pargs['høyde' .. i]) |
|||
else |
|||
widths[k] = getWidth(width, pargs['width' .. i] or pargs['bredde' .. i]) |
|||
end |
|||
widthsum[r] = widthsum[r] + widths[k] |
widthsum[r] = widthsum[r] + widths[k] |
||
end |
end |
||
Linje 128: | Linje 164: | ||
end |
end |
||
-- make sure the gap is non-negative |
|||
-- if total_width has been specified, rescale the bilde widths |
|||
if imagegap < 0 then imagegap = 0 end |
|||
local heights = {} |
|||
-- if total_width has been specified, rescale the image widths |
|||
if( isnotempty(totalwidth) ) then |
if( isnotempty(totalwidth) ) then |
||
totalwidth = tonumber(totalwidth) |
totalwidth = tonumber(totalwidth) |
||
Linje 136: | Linje 174: | ||
for r=1,rowcount do |
for r=1,rowcount do |
||
local koffset = k |
local koffset = k |
||
local tw = totalwidth - |
local tw = totalwidth - (3 + imagegap) * (perrow[r] - 1) - 12 |
||
local ar = {} |
local ar = {} |
||
local arsum = 0 |
local arsum = 0 |
||
for j=1,perrow[r] do |
for j=1,perrow[r] do |
||
k = k + 1 |
k = k + 1 |
||
if( k<= |
if( k<= imagecount ) then |
||
local i = |
local i = imagenumbers[k] |
||
local h = |
local h = heights[k] or 0 |
||
if (h > 0) then |
if (h > 0) then |
||
ar[j] = widths[k]/h |
ar[j] = widths[k]/h |
||
Linje 158: | Linje 196: | ||
for j=1,perrow[r] do |
for j=1,perrow[r] do |
||
k = k + 1 |
k = k + 1 |
||
if( k<= |
if( k<= imagecount ) then |
||
local i = |
local i = imagenumbers[k] |
||
widths[k] = math.floor(ar[j]*ht + 0.5) |
widths[k] = math.floor(ar[j]*ht + 0.5) |
||
ws = ws + widths[k] |
ws = ws + widths[k] |
||
Linje 170: | Linje 208: | ||
widthmax = math.max(widthmax, widthsum[r]) |
widthmax = math.max(widthmax, widthsum[r]) |
||
end |
end |
||
end |
end |
||
-- start building the array of |
-- start building the array of images, if there are images |
||
if( |
if( imagecount > 0 ) then |
||
-- compute width of outer div |
-- compute width of outer div |
||
local bodywidth = 0 |
local bodywidth = 0 |
||
for r=1,rowcount do |
for r=1,rowcount do |
||
if( widthmax == widthsum[r] ) then |
if( widthmax == widthsum[r] ) then |
||
bodywidth = widthmax + |
bodywidth = widthmax + (3 + imagegap) * (perrow[r] - 1) + 12 |
||
end |
end |
||
end |
end |
||
Linje 184: | Linje 222: | ||
bodywidth = math.max( 100, bodywidth - 8); |
bodywidth = math.max( 100, bodywidth - 8); |
||
local bg = pargs['bakgrunnsfarge'] or '' |
local bg = pargs['background color'] or pargs['bakgrunnsfarge'] or '' |
||
-- create the array of |
-- create the array of images |
||
local root = mw.html.create('div') |
local root = mw.html.create('div') |
||
root:addClass('thumb') |
root:addClass('thumb') |
||
root:addClass('tmulti') |
root:addClass('tmulti') |
||
-- root:addClass('tmulti-sandbox') |
|||
root:addClass(thumbclass[align] or 'tright') |
root:addClass(thumbclass[align] or 'tright') |
||
if( align == 'center' or align == 'centre' ) then |
if( align == 'center' or align == 'centre' ) then |
||
root:addClass('center') |
root:addClass('center') |
||
end |
|||
if( pargs['margin_top'] or args['margin_top']) then |
|||
root:css('margin-top', pargs['margin_top'] or args['margin_top']) |
|||
end |
|||
if( pargs['margin_bottom'] or args['margin_bottom']) then |
|||
root:css('margin-bottom', pargs['margin_bottom'] or args['margin_bottom']) |
|||
end |
end |
||
if( bg ~= '' ) then |
if( bg ~= '' ) then |
||
Linje 205: | Linje 238: | ||
local div = root:tag('div') |
local div = root:tag('div') |
||
div:addClass('thumbinner') |
div:addClass((border ~= 'infobox') and 'thumbinner multiimageinner' or 'multiimageinner') |
||
div:css('width', tostring(bodywidth) .. 'px') |
div:css('width', tostring(bodywidth) .. 'px') |
||
:css('max-width', tostring(bodywidth) .. 'px') |
:css('max-width', tostring(bodywidth) .. 'px') |
||
if( bg ~= '' ) then |
if( bg ~= '' ) then |
||
div:css('background-color', bg) |
div:css('background-color', bg) |
||
end |
|||
if( border == 'infobox' or border == 'none') then |
|||
div:css('border', 'none') |
|||
end |
end |
||
-- add the header |
-- add the header |
||
if( isnotempty(header) ) then |
if( isnotempty(header) ) then |
||
div:tag('div') |
div:tag('div') |
||
: |
:addClass('trow') |
||
: |
:tag('div') |
||
:addClass('theader') |
|||
:css('text-align', pargs['header_align'] or 'center') |
|||
:css(' |
:css('text-align', pargs['header_align']) |
||
:css('background-color', |
|||
(pargs['header_background'] ~= '') and pargs['header_background'] or nil) |
(pargs['header_background'] ~= '') and pargs['header_background'] or nil) |
||
:wikitext(header) |
:wikitext(header) |
||
end |
end |
||
-- loop through the |
-- loop through the images |
||
local k = 0 |
local k = 0 |
||
for r=1,rowcount do |
for r=1,rowcount do |
||
local rowdiv = div:tag('div'):addClass('trow'); |
|||
for j=1,perrow[r] do |
for j=1,perrow[r] do |
||
k = k + 1 |
k = k + 1 |
||
if( k <= |
if( k <= imagecount ) then |
||
local |
local imagediv = rowdiv:tag('div') |
||
imagediv:addClass('tsingle') |
|||
if dir ~= 'vertikal' then |
|||
bildediv:css('float', 'left') |
|||
end |
|||
if bg ~= '' then |
if bg ~= '' then |
||
imagediv:css('background-color', bg); |
|||
end |
end |
||
if imagegap > 1 and k < imagecount then |
|||
bildediv:css('margin', '1px') |
|||
if dir == 'vertical' then |
|||
imagediv:css('margin-bottom', tostring(imagegap) .. 'px') |
|||
local img = pargs['bilde' .. i] |
|||
elseif j < perrow[r] then |
|||
imagediv:css('margin-right', tostring(imagegap) .. 'px') |
|||
end |
|||
end |
|||
local i = imagenumbers[k] |
|||
local img = pargs['image' .. i] or pargs['bilde' .. i] |
|||
local w = widths[k] |
local w = widths[k] |
||
imagediv:css('width', tostring(2 + w) .. 'px') |
|||
:css('max-width', tostring(2 + w) .. 'px') |
:css('max-width', tostring(2 + w) .. 'px') |
||
imagediv:wikitext(renderImageCell(img, w, heights[k], |
|||
pargs['lenke' .. i], pargs['alt' .. i], |
pargs['link' .. i] or pargs['lenke' .. i], pargs['alt' .. i], |
||
pargs['bildetekst' .. i], capalign, imgstyle)) |
pargs['thumbtime' .. i], pargs['caption' .. i] or pargs['bildetekst' .. i], pargs['class' .. i], capalign, imgstyle, border)) |
||
end |
end |
||
end |
|||
-- only float content gives a parent height:0, so add a clearing div |
|||
if dir ~= 'vertikal' then |
|||
div:tag('div') |
|||
:css('clear', 'left') |
|||
end |
end |
||
end |
end |
||
-- add the footer |
-- add the footer |
||
if( isnotempty(footer) ) then |
if( isnotempty(footer) ) then |
||
local falign = string.lower(pargs['footer_align'] or args['footer_align'] or '') |
|||
falign = (falign == 'centre') and 'center' or falign |
|||
div:tag('div') |
div:tag('div') |
||
:addClass(' |
:addClass('trow') |
||
:css(' |
:css('display', (falign ~= '') and 'flow-root' or 'flex') |
||
:tag('div') |
|||
:css('text-align', pargs['footer_align'] or args['footer_align'] or 'left') |
|||
:addClass((border ~= 'infobox') and 'thumbcaption' or nil) |
|||
:css('background-color', |
|||
:css('text-align', (falign ~= '') and falign or nil) |
|||
:css('background-color', |
|||
(pargs['footer_background'] ~= '') and pargs['footer_background'] or nil) |
(pargs['footer_background'] ~= '') and pargs['footer_background'] or nil) |
||
:wikitext(footer) |
:wikitext(footer) |
||
end |
end |
||
return tostring(root) |
return tostring(root) |
||
Linje 268: | Linje 308: | ||
function p.render( frame ) |
function p.render( frame ) |
||
autoscaledimages = false |
|||
return renderMultiplebildes( frame ) |
|||
nonautoscaledimages = false |
|||
return frame:extensionTag {name = 'templatestyles', args = {src = 'Multiple image/styles.css', wrapper = ".tmulti"}} |
|||
.. renderMultipleImages( frame ) |
|||
.. (autoscaledimages and '[[Category:Pages using multiple image with auto scaled images]]' or '') |
|||
.. (nonautoscaledimages and '[[Category:Pages using multiple image with manual scaled images]]' or '') |
|||
end |
end |
||
p[''] = function( frame ) return p.render( frame:newChild{title = frame:getTitle()} ) end |
|||
return p |
return p |
Sideversjonen fra 3. okt. 2025 kl. 17:51
Dokumentasjon for denne modulen kan opprettes på Modul:Multiple image/dok
-- implements [[template:multiple image]] local p = {} local autoscaledimages local nonautoscaledimages local function isnotempty(s) return s and s:match( '^%s*(.-)%s*$' ) ~= '' end local function removepx(s) return tostring(s or ''):match('^(.*)[Pp][Xx]%s*$') or s end local function getdimensions(s, w, h) if tonumber(w) and tonumber(h) then nonautoscaledimages = true return tonumber(w), tonumber(h) end local file = s and mw.title.new('File:' .. mw.uri.decode(mw.ustring.gsub(s,'%|.*$',''), 'WIKI')) file = file and file.file or {width = 0, height = 0} w = tonumber(file.width) or 0 h = tonumber(file.height) or 0 autoscaledimages = true return w, h end local function renderImageCell(image, width, height, link, alt, thumbtime, caption, class, textalign, istyle, border) local root = mw.html.create('') local altstr = '|alt=' .. (alt or '') local classstr = class and ('|class=' .. class) or '' local linkstr = link and ('|link=' .. link) or '' local widthstr = '|' .. tostring(width) .. 'px' local thumbtimestr = '' if widthstr == '|-nanpx' then widthstr = '' end if isnotempty( thumbtime ) then thumbtimestr = '|thumbtime=' .. thumbtime end local imagediv = root:tag('div') imagediv:addClass((border ~= 'infobox') and 'thumbimage' or nil) imagediv:cssText(istyle) if( height ) then imagediv:css('height', tostring(height) .. 'px') imagediv:css('overflow', 'hidden') end imagediv:wikitext('[[file:' .. image .. classstr .. widthstr .. linkstr .. altstr .. thumbtimestr .. ']]') if isnotempty(caption) then local captiondiv = root:tag('div') captiondiv:addClass((border ~= 'infobox') and 'thumbcaption' or nil) if isnotempty(textalign) then captiondiv:addClass('text-align-' .. textalign) end captiondiv:wikitext(caption) end return tostring(root) end local function getWidth(w1, w2) local w if isnotempty(w1) then w = tonumber(w1) elseif isnotempty(w2) then w = tonumber(w2) end return w or 200 end local function getPerRow(pstr, ic) -- split string into array using any non-digit as a dilimiter local pr = mw.text.split(pstr or '', '[^%d][^%d]*') -- if split failed, assume a single row if (#pr < 1) then pr = {tostring(ic)} end -- convert the array of strings to an array of numbers, -- adding any implied/missing numbers at the end of the array local r = 1 local thisrow = tonumber(pr[1] or ic) or ic local prownum = {} while( ic > 0 ) do prownum[r] = thisrow ic = ic - thisrow r = r + 1 -- use the previous if the next is missing and -- make sure we don't overstep the number of images thisrow = math.min(tonumber(pr[r] or thisrow) or ic, ic) end return prownum end local function renderMultipleImages(frame) local pargs = frame:getParent().args local args = frame.args local width = removepx(pargs['width']) or removepx(pargs['bredde']) or '' local dir = pargs['direction'] or pargs['retning'] or '' local border = pargs['border'] or args['border'] or '' local align = pargs['align'] or args['align'] or pargs['justering'] or args['justering'] or (border == 'infobox' and 'center' or '') local capalign = pargs['caption_align'] or args['caption_align'] or pargs['justering_undertekst'] or args['justering_undertekst'] or '' local totalwidth = removepx(pargs['total_width']) or removepx(args['total_width']) or removepx(pargs['totalbredde']) or removepx(args['totalbredde']) or '' local imgstyle = pargs['image_style'] or args['image_style'] or pargs['bildestil'] or args['bildestil'] local header = pargs['header'] or pargs['title'] or pargs['overskrift'] or pargs['tittel'] or '' local footer = pargs['footer'] or pargs['undertekst'] or '' local imagegap = tonumber(pargs['image_gap'] or '1') or 1 local perrow = nil local thumbclass = { ["left"] = 'tleft', ["venstre"] = 'tleft', ["none"] = 'tnone', ["ingen"] = 'tnone', ["center"] = 'tnone', ["centre"] = 'tnone', ["senter"] = 'tnone', ["right"] = 'tright', ["høyre"] = 'tright' } -- find all the nonempty images local imagenumbers = {} local imagecount = 0 for k, v in pairs( pargs ) do -- matches imageX and bildeX local i = tonumber(tostring(k):match( '^%s*b?i[ml][ad]g?e([%d]+)%s*$' ) or '0') if( i > 0 and isnotempty(v) ) then table.insert( imagenumbers, i) imagecount = imagecount + 1 end end -- sort the imagenumbers table.sort(imagenumbers) -- create an array with the number of images per row perrow = getPerRow((dir == 'vertical' or dir == 'vertikal') and '1' or pargs['perrow'] or pargs['perrad'], imagecount) -- compute the number of rows local rowcount = #perrow -- store the image widths and compute row widths and maximum row width local heights = {} local widths = {} local widthmax = 0 local widthsum = {} local k = 0 for r=1,rowcount do widthsum[r] = 0 for c=1,perrow[r] do k = k + 1 if( k <= imagecount ) then local i = imagenumbers[k] if( isnotempty(totalwidth) ) then widths[k], heights[k] = getdimensions(pargs['image' .. i] or pargs['bilde' .. i], pargs['width' .. i] or pargs['bredde' .. i], pargs['height' .. i] or pargs['høyde' .. i]) else widths[k] = getWidth(width, pargs['width' .. i] or pargs['bredde' .. i]) end widthsum[r] = widthsum[r] + widths[k] end end widthmax = math.max(widthmax, widthsum[r]) end -- make sure the gap is non-negative if imagegap < 0 then imagegap = 0 end -- if total_width has been specified, rescale the image widths if( isnotempty(totalwidth) ) then totalwidth = tonumber(totalwidth) widthmax = 0 local k = 0 for r=1,rowcount do local koffset = k local tw = totalwidth - (3 + imagegap) * (perrow[r] - 1) - 12 local ar = {} local arsum = 0 for j=1,perrow[r] do k = k + 1 if( k<= imagecount ) then local i = imagenumbers[k] local h = heights[k] or 0 if (h > 0) then ar[j] = widths[k]/h heights[k] = h else ar[j] = widths[k]/100 end arsum = arsum + ar[j] end end local ht = tw/arsum local ws = 0 k = koffset for j=1,perrow[r] do k = k + 1 if( k<= imagecount ) then local i = imagenumbers[k] widths[k] = math.floor(ar[j]*ht + 0.5) ws = ws + widths[k] if heights[k] then heights[k] = math.floor(ht) end end end widthsum[r] = ws widthmax = math.max(widthmax, widthsum[r]) end end -- start building the array of images, if there are images if( imagecount > 0 ) then -- compute width of outer div local bodywidth = 0 for r=1,rowcount do if( widthmax == widthsum[r] ) then bodywidth = widthmax + (3 + imagegap) * (perrow[r] - 1) + 12 end end -- The body has a min-width of 100, which needs to be taken into account on specific widths bodywidth = math.max( 100, bodywidth - 8); local bg = pargs['background color'] or pargs['bakgrunnsfarge'] or '' -- create the array of images local root = mw.html.create('div') root:addClass('thumb') root:addClass('tmulti') -- root:addClass('tmulti-sandbox') root:addClass(thumbclass[align] or 'tright') if( align == 'center' or align == 'centre' ) then root:addClass('center') end if( bg ~= '' ) then root:css('background-color', bg) end local div = root:tag('div') div:addClass((border ~= 'infobox') and 'thumbinner multiimageinner' or 'multiimageinner') div:css('width', tostring(bodywidth) .. 'px') :css('max-width', tostring(bodywidth) .. 'px') if( bg ~= '' ) then div:css('background-color', bg) end if( border == 'infobox' or border == 'none') then div:css('border', 'none') end -- add the header if( isnotempty(header) ) then div:tag('div') :addClass('trow') :tag('div') :addClass('theader') :css('text-align', pargs['header_align']) :css('background-color', (pargs['header_background'] ~= '') and pargs['header_background'] or nil) :wikitext(header) end -- loop through the images local k = 0 for r=1,rowcount do local rowdiv = div:tag('div'):addClass('trow'); for j=1,perrow[r] do k = k + 1 if( k <= imagecount ) then local imagediv = rowdiv:tag('div') imagediv:addClass('tsingle') if bg ~= '' then imagediv:css('background-color', bg); end if imagegap > 1 and k < imagecount then if dir == 'vertical' then imagediv:css('margin-bottom', tostring(imagegap) .. 'px') elseif j < perrow[r] then imagediv:css('margin-right', tostring(imagegap) .. 'px') end end local i = imagenumbers[k] local img = pargs['image' .. i] or pargs['bilde' .. i] local w = widths[k] imagediv:css('width', tostring(2 + w) .. 'px') :css('max-width', tostring(2 + w) .. 'px') imagediv:wikitext(renderImageCell(img, w, heights[k], pargs['link' .. i] or pargs['lenke' .. i], pargs['alt' .. i], pargs['thumbtime' .. i], pargs['caption' .. i] or pargs['bildetekst' .. i], pargs['class' .. i], capalign, imgstyle, border)) end end end -- add the footer if( isnotempty(footer) ) then local falign = string.lower(pargs['footer_align'] or args['footer_align'] or '') falign = (falign == 'centre') and 'center' or falign div:tag('div') :addClass('trow') :css('display', (falign ~= '') and 'flow-root' or 'flex') :tag('div') :addClass((border ~= 'infobox') and 'thumbcaption' or nil) :css('text-align', (falign ~= '') and falign or nil) :css('background-color', (pargs['footer_background'] ~= '') and pargs['footer_background'] or nil) :wikitext(footer) end return tostring(root) end return '' end function p.render( frame ) autoscaledimages = false nonautoscaledimages = false return frame:extensionTag {name = 'templatestyles', args = {src = 'Multiple image/styles.css', wrapper = ".tmulti"}} .. renderMultipleImages( frame ) .. (autoscaledimages and '[[Category:Pages using multiple image with auto scaled images]]' or '') .. (nonautoscaledimages and '[[Category:Pages using multiple image with manual scaled images]]' or '') end p[''] = function( frame ) return p.render( frame:newChild{title = frame:getTitle()} ) end return p