Module:QuestList: Difference between revisions
Jump to navigation
Jump to search
Content added Content deleted
No edit summary |
No edit summary |
||
(6 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
require('strict') |
require('strict') |
||
require('Module:Mw.html extension') |
require('Module:Mw.html extension') |
||
local purge = require('Module:Purge')._purge |
|||
local parse = require('Module:Param Parse') |
local parse = require('Module:Param Parse') |
||
Line 7: | Line 8: | ||
function p.main(frame) |
function p.main(frame) |
||
local args = frame:getParent().args |
local args = frame:getParent().args |
||
local episode = '' |
|||
-- get all episodes by episode sequence order -- |
|||
local quest_type = '' |
|||
local episodes = mw.smw.ask{ |
|||
'[[Category:Episodes]]', |
|||
if (args.episode) then |
|||
('[[Name::%s]]'):format( args.episode or '+' ), |
|||
'[[Episode sequence number::+]]', |
|||
end |
|||
'[[Release Date::+]]', |
|||
'?Name#-', |
|||
if (args.type) then |
|||
'?Premium', |
|||
quest_type = ('[[Quest type::%s]]'):format( args.type ) |
|||
end |
|||
local data = mw.smw.ask{ |
|||
'[[Category:Quests]]', |
|||
episode, |
|||
quest_type, |
|||
'[[Name::+]]', |
|||
'?Difficulty', |
|||
'?Requirements', |
|||
'order=asc', |
'order=asc', |
||
'sort= |
'sort=Episode sequence number', |
||
' |
'link=none', |
||
' |
'format=plainlist' |
||
} |
} |
||
local table = mw.html.create('table') |
local table = mw.html.create('table') |
||
if (episodes == nil) then |
|||
:addClass('wikitable quest-table sortable align-center-2 align-left-3') |
|||
table:wikitext("No quests available for " .. args.episode .. " " .. purge('source-'..mw.uri.anchorEncode(args.episode), '(update)', 'span')) |
|||
:css{ |
|||
else |
|||
['width'] = '50%' |
|||
table |
|||
:addClass('wikitable quest-table align-center-2 align-center-3 align-left-4') |
|||
:attr{ cellspacing = '3' } |
|||
:css{ |
|||
:IF( args.episode ) |
|||
['width'] = '65%' |
|||
:tag('tr') |
|||
} |
|||
:attr{ cellspacing = '3' } |
|||
:wikitext( parse.episode_func( args.episode ) ) |
|||
for _, episode in ipairs(episodes) do |
|||
:done() |
|||
table |
|||
: |
:tag('tr') |
||
:tag(' |
:tag('th') |
||
: |
:attr('colspan', 4) |
||
:wikitextIf(episode.Premium == true, '[[File:Premium Pass icon.png|16px]] ') |
|||
:wikitext("Quest") |
|||
:wikitext('[[File:'.. episode.Name ..' episode icon.png|16px]] ' .. episode[1]) |
|||
:done() |
|||
:tag('th') |
|||
:wikitext("Difficulty") |
|||
:done() |
|||
:tag('th') |
|||
:wikitext("Requirements") |
|||
:done() |
|||
:done() |
|||
for _, quest in ipairs( data ) do |
|||
table |
|||
:tag('tr') |
|||
:tag('td') |
|||
:wikitext( quest[1] ) |
|||
:done() |
|||
:tag('td') |
|||
:css{ |
|||
['width'] = '100px' |
|||
} |
|||
:wikitext( parse.difficulty_func( tostring( quest['Difficulty']) ) ) |
|||
:done() |
|||
:tag('td') |
|||
:css{ |
|||
['width'] = '55%' |
|||
} |
|||
:IF(quest['Requirements']) |
|||
:tag('div') |
|||
:addClass('lighttable checklist') |
|||
:newline() |
|||
:wikitextIf( quest['Requirements'], quest['Requirements'] ) |
|||
:newline() |
|||
:done() |
:done() |
||
: |
:done() |
||
:tag('tr') |
|||
:tag('th') |
|||
:wikitext('Quest') |
|||
:done() |
:done() |
||
: |
:tag('th') |
||
: |
:wikitext('Type') |
||
:done() |
:done() |
||
:tag('th') |
|||
end |
|||
:wikitext('Difficulty') |
|||
:done() |
|||
:tag('th') |
|||
:wikitext('Requirements') |
|||
:done() |
|||
:done() |
|||
if ( episode ) then |
|||
-- get all quests for episode -- |
|||
local quests = mw.smw.ask{ |
|||
'[[Category:Quests]]', |
|||
'[[Name::+]]', |
|||
('[[Episode::%s]]'):format( episode.Name ), |
|||
'?Quest type', |
|||
'?Difficulty', |
|||
'?Requirements', |
|||
'order=asc', |
|||
'sort=Quest type,Episode_nth,Difficulty' |
|||
} |
|||
if ( quests ) then |
|||
-- get quests for episode -- |
|||
for _, quest in ipairs( quests ) do |
|||
table |
|||
:tag('tr') |
|||
:tag('td') |
|||
:wikitext( quest[1] ) |
|||
:done() |
|||
:tag('td') |
|||
:css { |
|||
['width'] = '50px' |
|||
} |
|||
:wikitext( quest['Quest type'] ) |
|||
:done() |
|||
:tag('td') |
|||
:wikitext( parse.difficulty_func( tostring(quest.Difficulty ) ) ) |
|||
:done() |
|||
:tag('td') |
|||
:css { |
|||
['width'] = '55%' |
|||
} |
|||
:tag('div') |
|||
:addClass('lighttable checklist') |
|||
:newline() |
|||
:wikitext( quest.Requirements ) |
|||
:newline() |
|||
:done() |
|||
:done() |
|||
:done() |
|||
end |
|||
end |
|||
end |
|||
end |
|||
table:done() |
|||
end |
|||
return table |
return table |
||
end |
end |
||
Latest revision as of 16:59, 18 December 2024
Documentation for this module may be created at Module:QuestList/doc
require('strict')
require('Module:Mw.html extension')
local purge = require('Module:Purge')._purge
local parse = require('Module:Param Parse')
local p = {}
function p.main(frame)
local args = frame:getParent().args
-- get all episodes by episode sequence order --
local episodes = mw.smw.ask{
'[[Category:Episodes]]',
('[[Name::%s]]'):format( args.episode or '+' ),
'[[Episode sequence number::+]]',
'[[Release Date::+]]',
'?Name#-',
'?Premium',
'order=asc',
'sort=Episode sequence number',
'link=none',
'format=plainlist'
}
local table = mw.html.create('table')
if (episodes == nil) then
table:wikitext("No quests available for " .. args.episode .. " " .. purge('source-'..mw.uri.anchorEncode(args.episode), '(update)', 'span'))
else
table
:addClass('wikitable quest-table align-center-2 align-center-3 align-left-4')
:css{
['width'] = '65%'
}
:attr{ cellspacing = '3' }
for _, episode in ipairs(episodes) do
table
:tag('tr')
:tag('th')
:attr('colspan', 4)
:wikitextIf(episode.Premium == true, '[[File:Premium Pass icon.png|16px]] ')
:wikitext('[[File:'.. episode.Name ..' episode icon.png|16px]] ' .. episode[1])
:done()
:done()
:tag('tr')
:tag('th')
:wikitext('Quest')
:done()
:tag('th')
:wikitext('Type')
:done()
:tag('th')
:wikitext('Difficulty')
:done()
:tag('th')
:wikitext('Requirements')
:done()
:done()
if ( episode ) then
-- get all quests for episode --
local quests = mw.smw.ask{
'[[Category:Quests]]',
'[[Name::+]]',
('[[Episode::%s]]'):format( episode.Name ),
'?Quest type',
'?Difficulty',
'?Requirements',
'order=asc',
'sort=Quest type,Episode_nth,Difficulty'
}
if ( quests ) then
-- get quests for episode --
for _, quest in ipairs( quests ) do
table
:tag('tr')
:tag('td')
:wikitext( quest[1] )
:done()
:tag('td')
:css {
['width'] = '50px'
}
:wikitext( quest['Quest type'] )
:done()
:tag('td')
:wikitext( parse.difficulty_func( tostring(quest.Difficulty ) ) )
:done()
:tag('td')
:css {
['width'] = '55%'
}
:tag('div')
:addClass('lighttable checklist')
:newline()
:wikitext( quest.Requirements )
:newline()
:done()
:done()
:done()
end
end
end
end
table:done()
end
return table
end
return p