4,979
edits
(Added 1/x values to Chances; Use Recipe icon for source icons when available; Merge Shop and Upgrade sources into Creation Table; Changed 'Inputs' to 'Costs'; Add output quantity for upgraded items; Fix Ash requirements, apparently) |
(Revert: "Use Recipe icon for source icons when available"; Purchase outputs no longer show icon text when in a table; Add more fallbacks to display N/A when data is nil) |
||
Line 100: | Line 100: | ||
qty = recipe.baseQuantity or 1 | qty = recipe.baseQuantity or 1 | ||
reqs = Icons._SkillReq(skill, lvl, false, (isAbyssal and 'melvorItA:Abyssal' or nil)) | reqs = Icons._SkillReq(skill, lvl, false, (isAbyssal and 'melvorItA:Abyssal' or nil)) | ||
source = Icons.Icon({ skill, type='skill', class=(isAbyssal and 'abyss-icon' or nil) }) | |||
-- Action time | -- Action time | ||
if recipe.baseMinInterval ~= nil then | if recipe.baseMinInterval ~= nil then | ||
Line 442: | Line 437: | ||
if showSource then tableHeader:tag('th'):wikitext('Source') end | if showSource then tableHeader:tag('th'):wikitext('Source') end | ||
if showRequirements then tableHeader:tag('th'):wikitext('Requires') end | if showRequirements then tableHeader:tag('th'):wikitext('Requires') end | ||
if showInputs then tableHeader:tag('th'):wikitext(' | if showInputs then tableHeader:tag('th'):wikitext('Costs') end | ||
if showOutputs then tableHeader:tag('th'):wikitext('Outputs') end | if showOutputs then tableHeader:tag('th'):wikitext('Outputs') end | ||
if showXP then tableHeader:tag('th'):wikitext('Exp') end | if showXP then tableHeader:tag('th'):wikitext('Exp') end | ||
Line 453: | Line 448: | ||
if showSource then recipeRow:tag('td'):wikitext(data.source) end | if showSource then recipeRow:tag('td'):wikitext(data.source) end | ||
if showRequirements then recipeRow:tag('td'):wikitext | if showRequirements then | ||
if data.reqs ~= nil then | |||
recipeRow:tag('td'):wikitext(data.reqs) | |||
else | |||
recipeRow:tag('td'):wikitext('N/A'):addClass('table-na') | |||
end | |||
end | |||
if showInputs | if showInputs then | ||
if data.costs ~= nil then | |||
addCostsRow(recipeRow, data, 1) | |||
else | |||
recipeRow:tag('td'):wikitext('N/A'):addClass('table-na') | |||
end | |||
end | end | ||
Line 465: | Line 468: | ||
local outputData = recipeRow:tag('td'):wikitext(data.qty) | local outputData = recipeRow:tag('td'):wikitext(data.qty) | ||
if data.center then outputData:addClass('center') end | if data.center then outputData:addClass('center') end | ||
elseif data.qty ~= nil then | |||
recipeRow:tag('td'):wikitext(Icons.Icon({ item.name, type='item', notext=true, qty=(data.qty or 1) })):addClass('center') | |||
else | else | ||
recipeRow:tag('td'):wikitext(Icons.Icon({ | recipeRow:tag('td'):wikitext('N/A'):addClass('table-na') | ||
end | |||
end | |||
if showXP then | |||
if data.skill ~= nil and data.xp ~= nil then | |||
local iconClass = (data.isAbyssal and 'abyss-icon' or nil) | |||
local xpText = (data.isAbyssal and ' AXP' or ' XP') | |||
recipeRow:tag('td') | |||
:wikitext(Icons.Icon({ data.skill, notext=true, type='skill', class=iconClass })) | |||
:wikitext(' ' .. Num.formatnum(data.xp) .. xpText) | |||
else | |||
recipeRow:tag('td'):wikitext('N/A'):addClass('table-na') | |||
end | end | ||
end | end | ||
if | if showTime then | ||
if data.time ~= nil then | |||
recipeRow:tag('td'):wikitext(Shared.timeString(data.time, true)):addClass('center') | |||
recipeRow:tag('td') | else | ||
recipeRow:tag('td'):wikitext('N/A'):addClass('table-na') | |||
end | |||
end | end | ||
if showChance then | if showChance then | ||
if data.weight ~= nil then | if data.weight ~= nil then | ||
Line 1,535: | Line 1,550: | ||
source = Shop._getPurchaseExpansionIcon(purchase) .. Common.getPurchaseIcon({purchase}) | source = Shop._getPurchaseExpansionIcon(purchase) .. Common.getPurchaseIcon({purchase}) | ||
-- Always show icon text when there's multiple items | -- Always show icon text when there's multiple items | ||
notext = false | -- notext = false | ||
else | else | ||
source = Icons.Icon({'Shop'}) .. ' Purchase' | source = Icons.Icon({'Shop'}) .. ' Purchase' | ||
Line 1,541: | Line 1,556: | ||
table.insert(tableData, { | table.insert(tableData, { | ||
['reqs'] = Common.getRequirementString(purchase.purchaseRequirements | ['reqs'] = Common.getRequirementString(purchase.purchaseRequirements), | ||
['isAbyssal'] = namespace == 'melvorItA', | ['isAbyssal'] = namespace == 'melvorItA', | ||
['costs'] = Shop.getCostString(purchase.cost, false), | ['costs'] = Shop.getCostString(purchase.cost, false), | ||
Line 1,726: | Line 1,741: | ||
"Arrow Shafts", | "Arrow Shafts", | ||
-- "Yew Longbow", | -- "Yew Longbow", | ||
"Blood Rune", | |||
"Steam Rune", | "Steam Rune", | ||
-- "Wolf", | -- "Wolf", | ||
Line 1,754: | Line 1,769: | ||
"Ancient Ring of Mastery", | "Ancient Ring of Mastery", | ||
"Mastery Token (Cooking)", | "Mastery Token (Cooking)", | ||
"Thief's Moneysack", | "Thief's Moneysack", | ||
"Golden Star", | "Golden Star", | ||
Line 1,770: | Line 1,781: | ||
"Gloom Vein Seed", | "Gloom Vein Seed", | ||
"Elite Chest", | "Elite Chest", | ||
"Gem Gloves", | |||
"Magic Bones", | |||
"Bowstring", | |||
"Superior Max Skillcape", | |||
"Abyssal Coin Contract II", | "Abyssal Coin Contract II", | ||
"Dark Summon Consumable II", | "Dark Summon Consumable II", | ||
"Abyssal Slayer Gear Upgrade Kit", | |||
"Topaz Bolts (Enchanted)", | |||
"Summoning Shard (Black)", | |||
"Dragon Javelin", | |||
"Skillers Body", | |||
} | } | ||
local checkFuncs = { | local checkFuncs = { |