Module:ItemCollection

-- --

--[=[

-- Lua script to get Collection Icon for Character or Collection Name --

-- Function: -- getCollection -- -- Parameters: -- 1: Character Name (or Collection short Name) --     Separate multiple characters with a dollar sign "$" -- 2: Icon Size in pixels --     "T" = include Text name/link, size = 25 --     "A" = link to section/anchor on current page --     "N" = Collection Name (Text only) --     "S" = IP/Collection Short Name (Text only) -- 3: Filtered list --     if present, then filtered list of collections is displayed --     filtering out collections with item [2] not nil --

-- Function: -- getGallery -- -- Parameters: -- None. --]=]

local p = {}

local collectionData = mw.loadData( 'Module:ItemCollection/data' ) local util = require('Module:Utility')

function oneCollection(collection, size, outType, pageName) local fileLink = ""

if collection then local collName = collection[1] if outType == 3 then return collName elseif outType == 4 then return collection[3] or collName end local file = mw.ustring.gsub(collName, "[\,\.']", "") file = mw.ustring.gsub(file, " ", "_") file = mw.ustring.lower(file)

if outType == 1 then fileLink = ""               .. collName                .. " ("        end

fileLink = fileLink .. "[[File:cc-"           .. file            .. "-l.png|x"            .. size            .. "px|"            .. collName            .. "|link="

if outType == 2 then fileLink = fileLink .. pageName .. "#"                       .. mw.uri.anchorEncode(collection[4] or collName) .. "]]"       else fileLink = fileLink .. "Category:" .. collName .. "]]"       end

if outType == 1 then fileLink = fileLink .. ")"       end    end    return fileLink end

function oneImage(collection) local fileLink = ""

if collection then local collName = collection[1] local file = mw.ustring.gsub(collName, "[\,\.']", "") file = mw.ustring.gsub(file, " ", "_") file = mw.ustring.lower(file)

fileLink = fileLink .. "cc-" .. file .. "-l.png|"           .. collName            .. "|link=Category:" .. collName end return fileLink end

-- Dislplay item links list (unavailable) local function itemList(eColl) local collections = {} for cName in mw.text.gsplit(eColl, "%s*%$%s*") do           cName = mw.text.decode(cName) if collectionData["Items"][cName] then local collNo = collectionData["Items"][cName][1]

if not collections[collNo] then local collData = collectionData["Collections"][collNo] if collData[1] == eColl then local tAll = {}

for _, data in pairs(collectionData) do							for _, col in pairs(data) do								if type(col) == "table" then local sortkey = collData[1] table.insert(tAll, {sortkey, col[2], col[3]}) end end end

table.sort(tAll, function(a,b) return a[1] < b[1] end)

local tOut = {} local space = ""

for _, data in ipairs(tAll) do							local premium = "" if data[2] == "true" then premium = "''" end local limited = "" if data[3] == "true" then limited = "''" end tLink = {space, premium, limited, "", data, "", limited, premium} tLink[5] = data table.insert(tOut, table.concat(tLink)) space = " · " end end end end end return table.concat(tOut) end

function p.getCollection(frame) local tArgs = util.getArgs(frame) local character = tArgs[1] or "" local size = tArgs[2] local filter = tArgs[3] or ""

local outType = 0

if not size or size == "" then size = "50" elseif not tonumber(size) then if size == "N" then outType = 3 size = "0" elseif size == "S" then outType = 4 size = "0" elseif size == "A" then outType = 2 size = "40" else outType = 1 size = "25" end end

local collectionFile = "" local space = "" local pageName = mw.title.getCurrentTitle.prefixedText

local collections = {}

character = mw.ustring.gsub(character, "^%s*(.-)%s*$", "%1") or '' if character == "" then character = mw.title.getCurrentTitle.text end

if character == "ALL" then for k, v in pairs(collectionData["Collections"]) do           if filter == "" or v[5] == nil then table.insert(collections, v)           end end

table.sort(collections, function(a,b) return a[2] < b[2] end)

for _, coll in ipairs(collections) do           collectionFile = collectionFile .. space .. oneCollection(coll, size, outType, pageName)

if outType == 1 or outType == 3 or outType == 4 then space = ", " else space = " " end end else for cName in mw.text.gsplit(character, "%s*%$%s*") do           cName = mw.text.decode(cName) if collectionData["Items"][cName] then local collNo = collectionData["Items"][cName][1]

if not collections[collNo] then local collData = collectionData["Collections"][collNo] collectionFile = collectionFile .. space .. oneCollection(collData, size, outType, pageName) if outType == 1 or outType == 3 or outType == 4 then space = ", " else space = " " end

collections[collNo] = 1 end end end end

--	local multi, eColl = string.match(character, "^([^%s,]+)%s*,?%s*([^,]*)$")

--	if multi then --		return itemList(eColl) --	else return collectionFile --	end end

-- to be called only from other LUA modules function p.actDataFile(character)

local dataFile = ""

if collectionData["Items"][character] then local collNo = collectionData["Items"][character][1]

if collectionData["Collections"][collNo] then data = collectionData["Collections"][collNo] dataFile = data[6] or data[3] or data[1] end end return dataFile end

function p.getGallery(frame) local collectionFile = '")	table.insert(tOut, table.concat(tGallery))	table.insert(tOut,'\n|}')

return table.concat(tOut) end

function p.getStorylines(frame) local collections = {} local storylines = "" local space = ""

for k, v in pairs(collectionData["Collections"]) do   	if k ~= 10 then if k ~= 9999 then table.insert(collections, v)       	end end end

table.sort(collections, function(a,b) return a[2] < b[2] end)

for _, coll in ipairs(collections) do       storylines = storylines .. space .. findCharacter(coll)

space = "\n\n" end

return frame:preprocess(storylines) end

return p