Module:Collection

local getArgs = require('Module:Arguments').getArgs local loader = require('Module:Loader')

local string, table, yesno = loader.require('String', 'Table', 'Yesno') local collectionData = loader.loadData('Collection/Data')

local p = {}

- -- Template:CollectionTable -- -- Makes a simple table that lists each reward from a collection for use on it's collection page - function p.collectionTable( frame ) local function split(s) return string.split(s, '%s*;%s*') end local function getlist(arg, i)		local temp = arg and split(arg) return temp and (temp[i] or temp[1]) or nil end local args = getArgs(frame) local collection = args['collection'] or args[1] or mw.title.getCurrentTitle.fullText local collectionPageTable = yesno(args['collectionPageTable']) -- get collection data from database local rows = table.deepCopy(collectionData[collection] or {}, true) -- parse input into the collection data structure for i = 1, 16 do		local rewards = args['reward'..i]		if rewards then rows[i] = { required = args['required' .. i], reward = table.map(split(rewards), function(reward, j)					return {						reward,						type = getlist(args['type' .. i], j),						comingsoon = getlist(args['comingsoon' .. i], j),						link = getlist(args['link' .. i], j),						nolink = getlist(args['nolink' .. i], j),					}				end), }		end end return mw.getCurrentFrame:preprocess(p._collectionTable( collection, rows, collectionPageTable )) end

function p._collectionTable( collection, colRowData, subTable ) local wikitable = mw.html.create('table'):addClass('wikitable margin-centered') if subTable then wikitable:css({ margin = 0, width = "100%", border = 0 }) end local row = wikitable:tag('tr') row:tag('th'):wikitext('LVL'):done row:tag('th'):wikitext('Required'):addClass('size-small'):done row:tag('th'):wikitext('Reward'):css(subTable and { width="100%" } or {}):done row:tag('th'):wikitext(''):done row:done for i, data in ipairs(colRowData) do		local tier = string._toRoman(i) local row = wikitable:tag('tr'):attr('id', tier) -- Tier row:tag('td'):addClass('centertxt'):css({ ['font-weight']='bold', ['font-family']='"Times New Roman", monospace' }):wikitext(tier):done -- Requirement row:tag('td'):wikitext(string._formatNum(data.required)):done -- Reward local td = row:tag('td') local cellData = {} for i, reward in pairs(data.reward) do			local _name, _type, _comingsoon, _link, _nolink = reward[1], reward.type or data.type or 'Recipe', reward.comingsoon or data.comingsoon, reward.link or data.link, reward.nolink or data.nolink table.push(cellData, getRewardLine(_name, _type, _comingsoon, _link, _nolink)) end td:wikitext(table.concat(cellData, ' ')):done -- Find SkyBlock Xp		td = row:tag('td') local xp = '' for i, reward in pairs(data.reward) do			if (reward.type or data.type or 'Recipe'):match('SkyBlock Experience') then xp = '' break end end td:wikitext(xp) row:done end wikitable:done return tostring(wikitable) end

function getRewardLine(reward, pType, pComingSoon, pLink, pNoLink) local function makeLink(reward, link, nolink, noImg) local name = reward nolink = yesno(nolink, false) -- For supplied link, no processing if reward:match('^%[%[.-%]%]$') then return reward end -- Check if it's an enchanted book local enchant, tier = string.match(reward, '^Enchanted Book %((.+) ([%dIVXivx]+)%)$') if enchant then name = ('Enchanted Book &%s %s&'):format(enchant, tier) end -- Check if it's a pet if reward:match('^Mystery%s[A-Z]+[a-z]+%sPet$') then link = string.sub(reward,9) end -- Output if noImg then return ('%s'):format(link or name, name) end return ():format(link or name, name, nolink and '|nolink=y' or ) end local isExp = pType:match('[Ee]xperience') and not pType:match('SkyBlock') local sbExp = pType:match('SkyBlock Experience') local unknownType = not not pType:match('[Cc]oming [Ss]oon') pComingSoon = unknownType or yesno(pComingSoon, false) if sbExp then return nil elseif isExp then local temp = pType if string.find(pType, ' [Ee]xperience$') then temp = (' Experience'):format(string.gsub(pType, '%s*[eE]xperience$', '')) end return ('+%s %s'):format(string._formatNum(reward), temp), pComingSoon else local comingSoonText = pComingSoon and string.wrapHtml('[Coming Soon] ', 'span', { class = 'color-red' }) or '' local noRewardYet = reward:lower:match('^coming soon$') return ('%s%s %s'):format(			comingSoonText,			noRewardYet and string.wrapHtml('Coming Soon', 'span', { class = 'color-red' }) or makeLink(reward, pLink, pNoLink, pComingSoon),			string.wrapHtml((noRewardYet or unknownType) and '' or pType, 'i')		) end end

-- Finish Module -- return p