Module:Gallery List

local p = {} local Data = mw.loadData("Module:Gallery List/Data")

local Franchise = require("Module:Franchise") local Term = require("Module:Term") local TermList = require("Module:Term List") local utilsArg = require("Module:UtilsArg") local utilsLayout = require("Module:UtilsLayout") local utilsPackage = require("Module:UtilsPackage") local utilsString = require("Module:UtilsString") local utilsTable = require("Module:UtilsTable") local _utilsError = utilsPackage.lazyLoad("Module:UtilsError")

local CATEGORY_INVALID_ARGS = ""

-- Generally the latest remake is the default tab but some remakes don't have enough images uploaded yet local DEFAULT_TAB_BLACKLIST = { ["OoT3D"] = true, ["MM3D"] = true, ["TPHD"] = true, ["SSHD"] = true, }

-- Enhanced ports may have the same assets as the original game -- There's no need to show a separate tab in those cases local ENHANCED_PORTS = { --["FSAE"] = true -- turns out FSAE does have its own sprites }

function p.Main(frame) local args, err = utilsArg.parse(frame:getParent.args, p.Templates["Gallery List"]) local categories = err and err.categoryText or "" local subjectType = args.subjectType local pagename = mw.title.getCurrentTitle.text

local tabData = {} local defaultTab = 1 for i, game in ipairs(Franchise.enumGames) do		local isListing = utilsString.endsWith(pagename, " in "..Franchise.shortName(game)) local subjects = args[game] if subjects then local gallery, subjectTerms = p.printGallery(subjectType, game, subjects, args) table.insert(tabData, {				label = Franchise.display(game),				content = gallery			}) if not DEFAULT_TAB_BLACKLIST[game] then defaultTab = #tabData end if not isListing then frame:expandTemplate({					title = "Location Features/Store",					args = {						feature = subjectType,						game = game,						subjects = table.concat(subjectTerms, ", ")					}				}) for j, remake in ipairs(Franchise.remakes(game)) do					if not args[remake] and not ENHANCED_PORTS[remake] then local gallery, subjectTerms = p.printGallery(subjectType, remake, subjects, args) table.insert(tabData, {							label = Franchise.display(remake),							content = gallery,						}) if not DEFAULT_TAB_BLACKLIST[remake] then defaultTab = #tabData end frame:expandTemplate({							title = "Location Features/Store",							args = {								feature = subjectType,								game = remake,								subjects = table.concat(subjectTerms, ", ")							}						}) end end end end end local output = utilsLayout.tabs(tabData, {		default = defaultTab,		tabOptions = {			collapse = true,		},	}) return output, categories end

function p.printGallery(subjectType, game, subjects, options) local options = options or {} local fileType = options.fileType local storeAs = options.storeAs

if not fileType then local graphics = Franchise.graphics(game) if subjectType == "Locations" then fileType = "" elseif graphics == "2D" then fileType = "Sprite" elseif subjectType == "Items" then fileType = "Icon" else fileType = "Model" end end

local links, terms = TermList.termList(game, subjects, { 		link = true, 		storeAs = storeAs 	}) local galleryEntries = {} for i= 1, #subjects do		local suffix = fileType == "" and "" or " "..fileType local startIdx, endIdx, variant = string.find(links[i], "%s*%[(%w+)][^%]]") if not variant then startIdx, endIdx, variant = string.find(links[i], "%s*%[(%w+)]$") end if variant then links[i] = string.gsub(links[i], "%s*%[(%w+)]", "", 1) if tonumber(variant) and tonumber(variant) < 10 then -- Why < 10 ? See Items in Phantom Hourglass suffix = suffix .. " " .. variant else suffix = " " .. variant .. " " .. suffix end end local file = string.format("File:%s %s%s.png", game, terms[i], suffix) local galleryEntry = string.format("%s|%s", file, links[i]) galleryEntries[i] = galleryEntry end galleryEntries = table.concat(galleryEntries, "\n") local size = Data.sizes[game] and Data.sizes[game][subjectType] or {} local gallery = mw.getCurrentFrame:extensionTag({		name = "gallery",		content = galleryEntries,		args = {			widths = options.widths or size.widths,			heights = options.heights or size.heights,			perrow= options.perrow,		}	}) terms = utilsTable.unique(terms) return gallery, terms end

function p.Schemas return { Data = { type = "record", required = true, properties = { {					name = "sizes", desc = "Sets the size of gallery thumbnails based on the  and   parameters of Template:Gallery List.", required = true, type = "map", keyPlaceholder = "game", keys = { type = "string" }, values = { type = "map", keyPlaceholder = "subjectType", keys = { type = "string" }, values = { type = "record", properties = { {									name = "widths", type = "string", required = true, desc = "A value in pixels corresponding to the  ." },								{									name = "heights", type = "string", required = true, desc = "A value in pixels corresponding to the  ." },							},						},					},				},			},		}	} end

function p.templateData local paramOrder = {1, "fileType", "storeAs", "perrow"} local params = { [1] = {			name = "subjectType", required = true, type = "string", enum = {"Characters", "Creatures", "Enemies", "Locations", "Items", "Materials", "Objects"}, desc = "The type of subject being listed.", trim = true, nilIfEmpty = true, },		fileType = { type = "string", desc = "Sets a custom filename suffix for gallery entries", trim = true, },		storeAs = { type = "string", desc = "Stores the list in the Sequences Cargo table for use by Template:Sort Value and Module:Sequences.", canOmit = true, trim = true, nilIfEmpty = true, },		perrow = { type = "number", desc = "Maximum number of thumbnails to show per row in the gallery.", trim = true, nilIfEmpty = true, canOmit = true, },		widths = { type = "string", desc = "A value in pixels. Sets the width of gallery entries, overriding any default set in Module:Gallery List/Data", trim = true, nilIfEmpty = true, canOmit = true, },		heights = { type = "string", desc = "A value in pixels. Sets the heights of gallery entries, overriding any default set in Module:Gallery List/Data", trim = true, nilIfEmpty = true, canOmit = true, }	}	for i, game in ipairs(Franchise.enumGames) do		if Franchise.isCanon(game) or Franchise.family(game) ~= "" then -- only games featured on the main page for now table.insert(paramOrder, game) params[game] = { type = "string", desc = "Comma-separated list of wiki page names referring to subjects in "..Franchise.display(game), trim = true, nilIfEmpty = true, split = true, }		end end return { format = "block", params = params, paramOrder = paramOrder, } end

p.Templates = { ["Gallery List"] = p.templateData }

return p