Module:Items/SourceTables/Sandbox: Difference between revisions

Change Category to Source; Source text is now the skill; Add Cartography and Astrology creation data; Add item chance where applicable (L-179); Show multiple quantity data for a select few items (L-211); Add Cooking Upgrades to Cooking Recipe Requirements; Use proper colspan on "Global" data when there was >= 3 table headers; Change XP to only show skill icon when in the table;
(Initial commit for overhauled Creation Tables (Status: Incomplete))
(Change Category to Source; Source text is now the skill; Add Cartography and Astrology creation data; Add item chance where applicable (L-179); Show multiple quantity data for a select few items (L-211); Add Cooking Upgrades to Cooking Recipe Requirements; Use proper colspan on "Global" data when there was >= 3 table headers; Change XP to only show skill icon when in the table;)
Line 24: Line 24:
-- (Major) Either add all the data from _getItemSourceTables into a single table or convert those over to a similar style table as well
-- (Major) Either add all the data from _getItemSourceTables into a single table or convert those over to a similar style table as well
-- If a single table is used, a new header will need to be added (maybe?); Could use 'Category'/'Source'
-- If a single table is used, a new header will need to be added (maybe?); Could use 'Category'/'Source'
-- Consider adding more skills into the sources; Stardust has a single source from Firemaking
-- Add the recipe as the category, such as 'Mithril Rock' for Mithril Ore
-- Ash and Withered Ash is showing a single source (Needs a fix in _getCreationTable)
-- Add chance data in _getCreationTable (Ex: Ash, Withered Ash, Stardust from FM)
-- If a table has a rowspan of 3 to (maxRows - 1) then the "Global" information needs to have the rowspan attribute (See Coal Ore's Base Quantity)
-- Should Skill XP be Value - Skill Icon - 'XP' or Skill Icon - Value - 'XP' ?
local tables = {}
local tables = {}
local checkItems = {
local checkItems = {
Line 38: Line 32:
'Ash', -- Requires a fix in _getCreationTable
'Ash', -- Requires a fix in _getCreationTable
'Withered Ash', -- Requires a fix in _getCreationTable
'Withered Ash', -- Requires a fix in _getCreationTable
'Generous Fire Spirit',
-- "Circlet of Rhaelyx", -- The following commented out items have no creation source data; This may appear later
-- "Circlet of Rhaelyx", -- The following commented out items have no creation source data; This may appear later
-- "Jewel of Rhaelyx",
-- "Jewel of Rhaelyx",
Line 47: Line 42:
"Gold Bar",
"Gold Bar",
"Raw Shrimp",
"Raw Shrimp",
"Coal Ore",
"Shrimp",
"Rune Platebody",
"Rune Platebody",
"Yew Longbow",
"Yew Longbow",
Line 67: Line 62:
-- "Infernal Claw",
-- "Infernal Claw",
-- "Chapeau Noir",
-- "Chapeau Noir",
"Stardust",
-- "Rope",
-- "Rope",
-- "Ancient Ring of Mastery",
-- "Ancient Ring of Mastery",
Line 73: Line 67:
-- "Gem Gloves",
-- "Gem Gloves",
"Thief's Moneysack",
"Thief's Moneysack",
-- "Golden Stardust",
"Stardust",
"Golden Stardust",
"Abyssal Stardust",
-- "Golden Star",
-- "Golden Star",
-- "Slayer Deterer",
-- "Slayer Deterer",
-- "Paper",
"Paper",
-- "Lemon",
-- "Lemon",
-- "Aranite Brush",
-- "Aranite Brush",
Line 112: Line 108:
local skill = ''
local skill = ''
local specialReq = nil
local specialReq = nil
local category = nil
local source = nil
local time = 0
local time = 0
local maxTime = nil
local maxTime = nil
Line 120: Line 116:
local qty = nil
local qty = nil
local costs = nil
local costs = nil
local chance = nil


local tableData = {}
local tableData = {}
Line 127: Line 124:
local skillIDs = {
local skillIDs = {
['Gathering'] = {
['Gathering'] = {
['Woodcutting'] = { recipeKey = 'trees' },
['Farming'] = { recipeKey = 'recipes', recipeType = 'item' },
['Fishing'] = { recipeKey = 'fish' },
['Woodcutting'] = { recipeKey = 'trees', recipeType = 'tree' },
['Firemaking'] = { recipeKey = 'logs' },
['Fishing'] = { recipeKey = 'fish', recipeType = 'item' },
['Mining'] = { recipeKey = 'rockData' },
['Firemaking'] = { recipeKey = 'logs', recipeType = 'item' },
['Farming'] = { recipeKey = 'recipes' },
['Mining'] = { recipeKey = 'rockData', recipeType = 'rock' },
['Harvesting'] = { recipeKey = 'veinData' }
['Cartography'] = { recipeKey = 'paperRecipes' },
['Harvesting'] = { recipeKey = 'veinData', recipeType = 'vein' }
},
},
['Artisan'] = {
['Artisan'] = {
Line 150: Line 148:
local skillData = SkillData[localSkillID]
local skillData = SkillData[localSkillID]
local skill = skillData.name
local skill = skillData.name
local lvl, isAbyssal, xp, qty, costs, category, time, maxTime = 0, false, 0, 0, nil, nil, 0, nil
local lvl, isAbyssal, xp, qty, source, costs, time, maxTime, chance = 0, false, 0, 0, nil, nil, 0, nil, nil
for i, recipe in ipairs(skillData[dataProp.recipeKey]) do
for i, recipe in ipairs(skillData[dataProp.recipeKey]) do
local hasProduct, specialReq = doesRecipeHaveItemID(recipe, itemID)
local hasProduct, specialReq = doesRecipeHaveItemID(recipe, itemID)
Line 157: Line 155:
xp = recipe.baseAbyssalExperience or recipe.baseExperience
xp = recipe.baseAbyssalExperience or recipe.baseExperience
qty = recipe.baseQuantity or 1
qty = recipe.baseQuantity or 1
source = Icons.Icon({ skill, type='skill', class=(isAbyssal and 'abyss-icon' or '') })
-- if recipe.name ~= nil then
-- category = Icons.Icon({ recipe.name, type=dataProp.recipeType })
-- end
if localSkillID == 'Farming' then
if localSkillID == 'Farming' then
costs = { recipe.seedCost }
costs = { recipe.seedCost }
local catData = GameData.getEntityByID(skillData.categories, recipe.categoryID)
local catData = GameData.getEntityByID(skillData.categories, recipe.categoryID)
category = catData.name
qty = 5 * catData.harvestMultiplier
qty = 5 * catData.harvestMultiplier
end
end
Line 173: Line 174:
elseif skillData.baseInterval ~= nil then
elseif skillData.baseInterval ~= nil then
time = skillData.baseInterval / 1000
time = skillData.baseInterval / 1000
elseif localSkillID == 'Cartography' then
time = 5
end
end
if itemID == 'melvorF:Ash' then
if itemID == 'melvorF:Ash' then
qty = time
qty = time
chance = '20%'
elseif itemID == 'melvorItA:Withered_Ash' then
qty = math.max(math.floor(recipe.abyssalLevel / 10), 1)
chance = '20%'
elseif itemID == 'melvorD:Generous_Fire_Spirit' then
chance = '0.1%'
elseif itemID == 'melvorF:Stardust' then
chance = '100%'
elseif localSkillID == 'Firemaking' and itemID == 'melvorD:Coal' then
chance = '40%'
end
end
-- Special requirements
-- Special requirements
Line 181: Line 194:
specialReq = Icons.Icon({'Mastery', notext=true}) .. Num.formatnum(recipe.totalMasteryRequired) .. ' total [[' .. skill .. ']] [[Mastery]]'
specialReq = Icons.Icon({'Mastery', notext=true}) .. Num.formatnum(recipe.totalMasteryRequired) .. ' total [[' .. skill .. ']] [[Mastery]]'
end
end
table.insert(tableData, { ['skill'] = skill, ['lvl'] = lvl, ['isAbyssal'] = isAbyssal, ['xp'] = xp, ['costs'] = costs, ['qty'] = qty, ['category'] = category, ['time'] = time, ['maxTime'] = maxTime, ['specialReq'] = specialReq })
table.insert(tableData, {
-- Assumes item has a single source per skill
['skill'] = skill,
break
['lvl'] = lvl,
['isAbyssal'] = isAbyssal,
['xp'] = xp,
['costs'] = costs,
['qty'] = qty,
['source'] = source,
['time'] = time,
['maxTime'] = maxTime,
['specialReq'] = specialReq,
['chance'] = chance
})
-- Most recipes have a single item source or the item source data
-- is nearly all the same. The following items have some uniqueness
if not Shared.contains({'melvorF:Ash', 'melvorItA:Withered_Ash', 'melvorAoD:Paper'}, itemID) then break end
end
end
end
end
Line 193: Line 219:
local skillData = SkillData[localSkillID]
local skillData = SkillData[localSkillID]
local skill = skillData.name
local skill = skillData.name
local lvl, isAbyssal, xp, qty, category, req, time, maxTime = 0, false, 0, 0, nil, nil, 0, nil
local lvl, isAbyssal, xp, qty, source, costs, time, maxTime = 0, false, 0, 0, Icons.Icon({ skill, type='skill' }), nil, 0, nil
for i, recipe in ipairs(skillData.recipes) do
for i, recipe in ipairs(skillData.recipes) do
if recipe.productID == itemID or
if recipe.productID == itemID or
Line 201: Line 227:
xp = recipe.baseAbyssalExperience or recipe.baseExperience
xp = recipe.baseAbyssalExperience or recipe.baseExperience
qty = recipe.baseQuantity or 1
qty = recipe.baseQuantity or 1
-- Recipe Category
source = Icons.Icon({ skill, type='skill', class=(isAbyssal and 'abyss-icon' or '') })
if recipe.categoryID ~= nil then
local catData = GameData.getEntityByID(SkillData[localSkillID].categories, recipe.categoryID)
category = catData.modifierName or catData.name or nil
end
-- Action time
-- Action time
if recipe.baseMinInterval ~= nil then
if recipe.baseMinInterval ~= nil then
Line 213: Line 235:
end
end
elseif recipe.baseInterval ~= nil then
elseif recipe.baseInterval ~= nil then
time = recipe.baseInterval /1000
time = recipe.baseInterval / 1000
elseif skillData.baseInterval ~= nil then
elseif skillData.baseInterval ~= nil then
time = skillData.baseInterval / 1000
time = skillData.baseInterval / 1000
Line 223: Line 245:
if levelUnlock ~= nil then
if levelUnlock ~= nil then
specialReq = Icons._MasteryReq(item.name, levelUnlock.level, false)
specialReq = Icons._MasteryReq(item.name, levelUnlock.level, false)
end
end
if localSkillID == 'Cooking' then
-- Cooking includes the required utility (fire, furnace, pot) as a special requirement
local cookingCatIcon = {
["melvorD:Fire"] = 'Normal Cooking Fire',
["melvorD:Furnace"] = 'Basic Furnace',
["melvorD:Pot"] = 'Basic Pot'
}
local categoryIconName, categoryName = cookingCatIcon[recipe.categoryID], nil
local recipeCategory = GameData.getEntityByID(SkillData.Cooking.categories, recipe.categoryID)
if recipeCategory ~= nil then
categoryName = recipeCategory.modifierName or recipeCategory.name
end
if categoryIconName ~= nil and categoryName ~= nil then
specialReq = Icons.Icon({'Cooking', categoryName, section = 'Cooking Upgrades', img = categoryIconName, type = 'upgrade'})
end
end
end
end
Line 252: Line 290:
end
end
end
end
req = table.concat(shardCostArray, '<br>')
costs = table.concat(shardCostArray, '<br>')
if not Shared.tableIsEmpty(otherCostArray) then
if not Shared.tableIsEmpty(otherCostArray) then
local costLen = Shared.tableCount(otherCostArray)
local costLen = Shared.tableCount(otherCostArray)
req = req .. '<br>' .. (costLen == 1 and '' or 'and one of the following:<br>') .. table.concat(otherCostArray, "<br>'''OR''' ")
costs = costs .. '<br>' .. (costLen == 1 and '' or 'and one of the following:<br>') .. table.concat(otherCostArray, "<br>'''OR''' ")
end
end
specialReq = 'At least 1 ' .. Icons.Icon({'Summoning%23Summoning Marks', item.name, img=item.name, type='mark'}) .. ' mark discovered'
specialReq = 'At least 1 ' .. Icons.Icon({'Summoning%23Summoning Marks', item.name, img=item.name, type='mark'}) .. ' mark discovered'
table.insert(tableData, { ['skill'] = skill, ['lvl'] = lvl, ['isAbyssal'] = isAbyssal, ['xp'] = xp, ['costs'] = req, ['qty'] = qty, ['category'] = category, ['time'] = time, ['maxTime'] = nil, ['specialReq'] = specialReq })
table.insert(tableData, {
['skill'] = skill,
['lvl'] = lvl,
['isAbyssal'] = isAbyssal,
['xp'] = xp,
['costs'] = costs,
['qty'] = qty,
['source'] = source,
['time'] = time,
['maxTime'] = nil,
['specialReq'] = specialReq
})
-- Some items (such as Arrow shafts) have multiple recipes
-- Some items (such as Arrow shafts) have multiple recipes
elseif type(recipe.alternativeCosts) == 'table' then
elseif type(recipe.alternativeCosts) == 'table' then
Line 274: Line 323:
end
end
costsStr = costsStr .. (Common.getCostString({ ["items"] = {}, ["currencies"] = recipe.currencyCosts}) or '')
costsStr = costsStr .. (Common.getCostString({ ["items"] = {}, ["currencies"] = recipe.currencyCosts}) or '')
table.insert(tableData, { ['skill'] = skill, ['lvl'] = lvl, ['isAbyssal'] = isAbyssal, ['xp'] = xp, ['costs'] = costsStr, ['qty'] = Num.formatnum(qty * altCost.quantityMultiplier), ['category'] = category, ['time'] = time, ['maxTime'] = maxTime, ['specialReq'] = specialReq })
table.insert(tableData, {
['skill'] = skill,
['lvl'] = lvl,
['isAbyssal'] = isAbyssal,
['xp'] = xp,
['costs'] = costsStr,
['qty'] = Num.formatnum(qty * altCost.quantityMultiplier),
['source'] = Icons.Icon({ skill, type='skill' }),
['time'] = time,
['maxTime'] = maxTime,
['specialReq'] = specialReq
})
end
end
-- Finally, normal recipes with a single set of item costs
-- Finally, normal recipes with a single set of item costs
elseif type(recipe.itemCosts) == 'table' and not Shared.tableIsEmpty(recipe.itemCosts) then
elseif type(recipe.itemCosts) == 'table' and not Shared.tableIsEmpty(recipe.itemCosts) then
table.insert(tableData, { ['skill'] = skill, ['lvl'] = lvl, ['isAbyssal'] = isAbyssal, ['xp'] = xp, ['costs'] = recipe.itemCosts, ['qty'] = qty, ['category'] = category, ['time'] = time, ['maxTime'] = maxTime, ['specialReq'] = specialReq, ['currencyCost'] = recipe.currencyCosts })
table.insert(tableData, {
['skill'] = skill,
['lvl'] = lvl,
['isAbyssal'] = isAbyssal,
['xp'] = xp,
['costs'] = recipe.itemCosts,
['qty'] = qty,
['source'] = Icons.Icon({ skill, type='skill' }),
['time'] = time,
['maxTime'] = maxTime,
['specialReq'] = specialReq,
['currencyCost'] = recipe.currencyCosts
})
end
end
end
end
Line 289: Line 361:
for i, altSpell in ipairs(Magic.getSpellsBySpellBook('altMagic')) do
for i, altSpell in ipairs(Magic.getSpellsBySpellBook('altMagic')) do
if altSpell.produces == item.id then
if altSpell.produces == item.id then
table.insert(tableData, { ['skill'] = 'Magic', ['lvl'] = altSpell.level, ['isAbyssal'] = false, ['xp'] = altSpell.baseExperience, ['costs'] = altSpell.runesRequired, ['qty'] = altSpell.productionRatio, ['category'] = altSpell.name, ['time'] = 2, ['maxTime'] = 2, ['altCosts'] = Magic._getAltSpellCostText(altSpell) })
table.insert(tableData, {
['skill'] = 'Magic',
['lvl'] = altSpell.level,
['isAbyssal'] = false,
['xp'] = altSpell.baseExperience,
['costs'] = altSpell.runesRequired,
['qty'] = altSpell.productionRatio,
['source'] = Icons.Icon({ altSpell.name, type='spell' }),
['time'] = 2,
['maxTime'] = 2,
['altCosts'] = Magic._getAltSpellCostText(altSpell)
})
end
end
 
-- Add in Astrology creation items manually since each constellation has (mostly)
-- the same creation information so looping through them is not necessary
if Shared.contains({ 'melvorF:Stardust', 'melvorF:Golden_Stardust', 'melvorItA:Abyssal_Stardust', 'melvorItA:Eternal_Stardust' }, itemID) then
local namespace, localID = Shared.getLocalID(itemID)
local isAbyssal = namespace == 'melvorItA'
local chance = nil
for i, itemChanceData in ipairs(SkillData.Astrology.baseRandomItemChances) do
if itemChanceData.itemID == itemID then
chance = itemChanceData.chance .. '%'
break
end
end
end
table.insert(tableData, {
['skill'] = 'Astrology',
['lvl'] = 1,
['isAbyssal'] = isAbyssal,
['xp'] = (isAbyssal and 1238 or 5),
['source'] = Icons.Icon({ 'Astrology', type='skill', class=(isAbyssal and 'abyss-icon' or '')}),
['time'] = 3,
['chance'] = chance
})
end
end


Line 336: Line 442:


function p.buildCreationTable2(tableData, item)
function p.buildCreationTable2(tableData, item)
local showCategory = false
local showSource = false
local showRequirements = false
local showRequirements = false
local showInputs = false
local showInputs = false
Line 343: Line 449:
local showTime = false
local showTime = false
local showChance = false
local showChance = false
local colspan = -1


for i, data in ipairs(tableData) do
for i, data in ipairs(tableData) do
if not showCategory and tableData[1].category ~= tableData[i].category then showCategory = true end
if not showSource and tableData[1].source ~= tableData[i].source then
if not showRequirements and tableData[1].skill ~= tableData[i].skill then showRequirements = true end
showSource = true
if not showInputs and tableData[1].costs ~= tableData[i].costs then showInputs = true end
colspan = colspan + 1
if not showOutputs and tableData[1].qty ~= tableData[i].qty then showOutputs = true end
end
if not showXP and tableData[1].xp ~= tableData[i].xp then showXP = true end
if not showRequirements and tableData[1].skill ~= tableData[i].skill then
if not showTime and tableData[1].time ~= tableData[i].time then showTime = true end
showRequirements = true
if not showChance and tableData[1].chance ~= tableData[i].chance then showChance = true end
colspan = colspan + 1
end
if not showInputs and tableData[1].costs ~= tableData[i].costs then
showInputs = true
colspan = colspan + 1
end
if not showOutputs and tableData[1].qty ~= tableData[i].qty then
showOutputs = true
colspan = colspan + 1
end
if not showXP and tableData[1].xp ~= tableData[i].xp then
showXP = true
colspan = colspan + 1
end
if not showTime and tableData[1].time ~= tableData[i].time then
showTime = true
colspan = colspan + 1
end
if not showChance and tableData[1].chance ~= tableData[i].chance then
showChance = true
colspan = colspan + 1
end
end
end


local function addCostsRow(row, data)
local function addCostsRow(row, data, colspan)
local costsRow = row:tag('td')
local costsRow = row:tag('td'):attr('colspan', (colspan >= 2 and colspan or 1))
if type(data.costs) == 'table' then
if type(data.costs) == 'table' then
for i, mat in ipairs(data.costs) do
for i, mat in ipairs(data.costs) do
Line 383: Line 511:
local tableHeader = resultTable:tag('tr')
local tableHeader = resultTable:tag('tr')


if showCategory then tableHeader:tag('th'):wikitext('Category') end
if showSource then tableHeader:tag('th'):wikitext('Source') end
if showRequirements then tableHeader:tag('th'):wikitext('Requirements') end
if showRequirements then tableHeader:tag('th'):wikitext('Requires') end
if showInputs then tableHeader:tag('th'):wikitext('Inputs') end
if showInputs then tableHeader:tag('th'):wikitext('Inputs') end
if showOutputs then tableHeader:tag('th'):wikitext('Outputs') end
if showOutputs then tableHeader:tag('th'):wikitext('Outputs') end
Line 396: Line 524:
local recipeRow = resultTable:tag('tr')
local recipeRow = resultTable:tag('tr')


if showCategory then recipeRow:tag('td'):wikitext(data.category) end
if showSource then recipeRow:tag('td'):wikitext(data.source) end
if showRequirements then
if showRequirements then
Line 407: Line 535:


if showInputs and data.costs ~= nil then
if showInputs and data.costs ~= nil then
addCostsRow(recipeRow, data)
addCostsRow(recipeRow, data, 1)
elseif showInputs then
elseif showInputs then
recipeRow:tag('td'):wikitext('N/A'):addClass('table-na')
recipeRow:tag('td'):wikitext('N/A'):addClass('table-na')
Line 413: Line 541:


if showOutputs then recipeRow:tag('td'):wikitext(Icons.Icon({item.name, type='item', notext=true, qty=data.qty})):addClass('center') end
if showOutputs then recipeRow:tag('td'):wikitext(Icons.Icon({item.name, type='item', notext=true, qty=data.qty})):addClass('center') end
if showXP then recipeRow:tag('td'):wikitext(Num.formatnum(data.xp) .. ' ' .. Icons.Icon({data.skill, notext=true, type='skill'}) .. (data.isAbyssal and ' AXP' or ' XP')):addClass('center') end
if showXP then recipeRow:tag('td'):wikitext(Icons.Icon({data.skill, (Num.formatnum(data.xp) .. (data.isAbyssal and ' AXP' or ' XP')), nolink=true, type='skill'})):addClass('center') end
if showTime then recipeRow:tag('td'):wikitext(Shared.timeString(data.time, true)):addClass('center') end
if showTime then recipeRow:tag('td'):wikitext(Shared.timeString(data.time, true)):addClass('center') end
if showChance then recipeRow:tag('td'):wikitext(data.chance):addClass('center') end
if showChance then recipeRow:tag('td'):wikitext(data.chance):addClass('center') end
end
end


if not showCategory and tableData[1].category ~= nil then
if not showSource and tableData[1].source ~= nil then
resultTable:tag('tr')
resultTable:tag('tr')
:tag('th')
:tag('th')
:wikitext('Category') -- TODO: Rename to Source or Recipe? Category makes sense for recipe categories but not really spells. Source could be the skill that's used for non-spells??
:wikitext('Source')
:css('text-align', 'right')
:css('text-align', 'right')
:tag('td'):wikitext(tableData[1].category) -- TODO: Use Icon template for category. This will require adding overrides to the Icons module for each standard recipe category. Icons will (ideally) be required for Alt Magic Recipes as the category will be the spell that is used
:tag('td'):attr('colspan', (colspan >= 2 and colspan or 1)):wikitext(tableData[1].source)
-- This value will need to be passed in as a completed link/icon template as the output will vary by recipe (Such as Barrier Dust having both a Spell and 'Special Items' category)
end
end
if not showRequirements and tableData[1].skill ~= nil and tableData[1].lvl ~= nil then
if not showRequirements and tableData[1].skill ~= nil and tableData[1].lvl ~= nil then
Line 431: Line 558:
:wikitext('Requirements')
:wikitext('Requirements')
:css('text-align', 'right')
:css('text-align', 'right')
local reqData = reqRow:tag('td')
local reqData = reqRow:tag('td'):attr('colspan', (colspan >= 2 and colspan or 1))
reqData:wikitext(Icons._SkillReq(tableData[1].skill, tableData[1].lvl, false, (tableData[1].isAbyssal and "melvorItA:Abyssal" or nil)))
reqData:wikitext(Icons._SkillReq(tableData[1].skill, tableData[1].lvl, false, (tableData[1].isAbyssal and "melvorItA:Abyssal" or nil)))


Line 444: Line 571:
:css('text-align', 'right')
:css('text-align', 'right')
addCostsRow(costRow, tableData[1])
addCostsRow(costRow, tableData[1], colspan)
end
end
if not showOutputs and tableData[1].qty ~= nil then
if not showOutputs and tableData[1].qty ~= nil then
Line 451: Line 578:
:wikitext('Outputs')
:wikitext('Outputs')
:css('text-align', 'right')
:css('text-align', 'right')
:tag('td'):wikitext(Icons.Icon({item.name, type='item', qty=tableData[1].qty}))
:tag('td'):attr('colspan', (colspan >= 2 and colspan or 1)):wikitext(Icons.Icon({ item.name, type='item', qty=tableData[1].qty }))
end
end
if not showXP and tableData[1].xp ~= nil then
if not showXP and tableData[1].xp ~= nil then
Line 458: Line 585:
:wikitext('Base Experience')
:wikitext('Base Experience')
:css('text-align', 'right')
:css('text-align', 'right')
:tag('td'):wikitext(Num.formatnum(tableData[1].xp) .. ' ' .. Icons.Icon({tableData[1].skill, notext=true, type='skill'}) .. (tableData[1].isAbyssal and ' AXP' or ' XP'))
:tag('td'):attr('colspan', (colspan >= 2 and colspan or 1)):wikitext(Num.formatnum(tableData[1].xp) .. (tableData[1].isAbyssal and ' AXP' or ' XP'))
end
end
if not showTime and tableData[1].time ~= nil then
if not showTime and tableData[1].time ~= nil then
Line 464: Line 591:
local timeHeader = resultTable:tag('th')
local timeHeader = resultTable:tag('th')
timeHeader
timeHeader
:wikitext('Base Creation Time')
:wikitext('Base Time')
:css('text-align', 'right')
:css('text-align', 'right')


local timeData = timeHeader:tag('td')
local timeData = timeHeader:tag('td'):attr('colspan', (colspan >= 2 and colspan or 1))
timeData:wikitext(Shared.timeString(tableData[1].time, true))
timeData:wikitext(Shared.timeString(tableData[1].time, true))


Line 477: Line 604:
resultTable:tag('tr')
resultTable:tag('tr')
:tag('th')
:tag('th')
:wikitext('Base Recipe Chance')
:wikitext('Base Chance')
:css('text-align', 'right')
:css('text-align', 'right')
:tag('td'):wikitext(tableData[1].chance)
:tag('td'):attr('colspan', (colspan >= 2 and colspan or 1)):wikitext(tableData[1].chance)
end
end