Module:Sandbox/FeRDNYC/Episode table explained

-- This module implements and .

local HTMLcolor = mw.loadData('Module:Color contrast/colors')

---------------------------------------------------------------------------------- EpisodeTable class-- The main class.--------------------------------------------------------------------------------

local contrast_ratio = require('Module:Color contrast')._ratiolocal EpisodeTable =

function EpisodeTable.cell(background, width, text, reference) local cell = mw.html.create('th') -- Cell cell:attr('scope','col') :css('background-color',background or '#CCCCFF') :css('width',width ~= and width .. '%' or nil) :wikitext(text) -- Reference if reference and reference ~= then cell:wikitext(" " .. EpisodeTable.reference(reference, background)) end return cellend

function EpisodeTable.reference(reference, background) local link1_cr = contrast_ratio local link2_cr = contrast_ratio local refspan = mw.html.create('span') :wikitext(reference) if link1_cr < 7 or link2_cr < 7 then refspan :css('background-color','white') :css('padding','1px') :css('display','inline-block') :css('line-height','50%') end return tostring(refspan)end

function EpisodeTable.abbr(text,title) local abbr = mw.html.create('abbr') :attr('title',title) :wikitext(text) return tostring(abbr)end

function EpisodeTable.part(frame,args) local row = mw.html.create('tr') local black_cr = contrast_ratio local white_cr = contrast_ratio local displaytext = (not args.nopart and 'Part ' or ) .. (args.p or ) row:tag('td') :attr('colspan',13) :css('text-align','center') :css('background-color', args.c) :css('color', black_cr > white_cr and 'black' or 'white') :wikitext("" .. frame:expandTemplate .. "" .. (args.r and " " .. EpisodeTable.reference(args.r, args.c) or )) return tostring(row)end

function EpisodeTable.new(args) args = args or local categories = local background = (args.background and args.background ~= and args.background ~= '#') and args.background or nil -- Add # to background if necessary if background ~= nil and HTMLcolor[background]

nil then background = '#'..(mw.ustring.match(background, '^[%s#]*([a-fA-F0-9]*)[%s]*$') or ) end -- Create episode table local root = mw.html.create('table') local sort_cond = mw.html.create('includeonly') sort_cond:wikitext('sortable')

root :addClass('wikitable') :addClass('plainrowheaders') :addClass('wikiepisodetable') :addClass(tostring(sort_cond)) :css('width', args.total_width and string.gsub(args.total_width,'%%',) .. '%' or '100%') -- Caption if args.caption then root:tag('caption'):wikitext(args.caption) end -- Colour contrast; add to category only if it's in the mainspace local title = mw.title.getCurrentTitle local black_cr = contrast_ratio local white_cr = contrast_ratio if title.namespace

0 and (args.background and args.background ~= and args.background ~= '#') and black_cr < 7 and white_cr < 7 then categories = categories .. '' end -- Main row local mainRow = root:tag('tr') mainRow :css('color', background and (black_cr > white_cr and 'black' or 'white') or 'black') :css('text-align', 'center') -- Cells do local used_season = false local country = args.country ~= and args.country ~= nil local viewers = (country and args.country or ) .. ' ' .. (country and 'v' or 'V') .. 'iewers' .. ((not args.viewers_type or args.viewers_type ~= ) and '
(' .. (args.viewers_type or 'millions') .. ')' or ) local cellNames = for k,v in pairs(cellNames) do local thisCell = args[v[1]] or args[v[2]] if thisCell and (v[1] ~= 'series' or (v[1]

'series' and used_season

false)) then if v[1]

'season' then used_season = true end if (k <= 3 and thisCell

) then thisCell = '5' end local thisCellT = args[v[1] .. 'T'] or args[v[2] .. 'T'] local thisCellR = args[v[1] .. 'R'] or args[v[2] .. 'R'] mainRow:node(EpisodeTable.cell(background, thisCell, thisCellT or v[3], thisCellR)) end end -- Episodes root:node(args.episodes) end return (args.dontclose and mw.ustring.gsub(tostring(root), "", "") or tostring(root)) .. categoriesend

---------------------------------------------------------------------------------- Exports--------------------------------------------------------------------------------

local p =

function p.main(frame) local args = require('Module:Arguments').getArgs(frame,) return EpisodeTable.new(args)end

function p.part(frame) local args = require('Module:Arguments').getArgs(frame,) return EpisodeTable.part(frame,args)end

function p.ref(frame) local args = require('Module:Arguments').getArgs(frame,) return EpisodeTable.reference(args.r,args.b)end

return p