Module:Subpages 3: Difference between revisions
Content added Content deleted
No edit summary |
Tag: Undo |
||
(18 intermediate revisions by 2 users not shown) | |||
Line 9: | Line 9: | ||
"Analysis", "Characters", "Laconic", "Recap", "Trivia", "Setting", "YMMV", |
"Analysis", "Characters", "Laconic", "Recap", "Trivia", "Setting", "YMMV", |
||
"Fridge", "Fanfic Recs", "Haiku", "Headscratchers", "Ho Yay", "Image Links", |
"Fridge", "Fanfic Recs", "Haiku", "Headscratchers", "Ho Yay", "Image Links", |
||
"Memes", "Radar", "Quotes", "Reviews", "Useful Notes", "WMG" |
"Memes", "Radar", "Quotes", "Reviews", "Source", "Useful Notes", "WMG" |
||
}, |
}, |
||
["creator"] = {"YMMV", "Quotes", "Fanfic Recs", "Analysis", "Trivia", "WMG", "Image Links", "Haiku", "Laconic"} |
["creator"] = {"YMMV", "Quotes", "Fanfic Recs", "Analysis", "Trivia", "WMG", "Image Links", "Haiku", "Laconic"} |
||
Line 15: | Line 15: | ||
local crowners = { |
local crowners = { |
||
["trope"] = { "Animation", "Animated Films", "Anime", "Anime and Manga", "Board Games", "Comics", "Comic Books", |
["trope"] = { "Animation", "Animated Films", "Anime", "Anime and Manga", "Board Games", "Comics", "Comic Books", |
||
"Fan Works", " |
"Fan Works", "Fanfic", "Fanfiction", "Fan Fiction", "Film", "Folklore", "Literature", |
||
" |
"Live Action Television", "Live Action TV", "Machinima", |
||
" |
"Manga", "Manga and Anime", "Music", "Musicians", "New Media", |
||
"Opera", "Professional Wrestling", "Puppet Shows", "Radio", "Tabletop Games", "Tabletop RPGs", |
|||
"Television", "TV", |
|||
"Theatre", "Theater", "Toys", |
"Theatre", "Theater", "Toys", |
||
"Webcomics", "Video Games", "Visual Art", "Visual Novels", |
"Webcomics", "Video Games", "Visual Art", "Visual Novels", |
||
Line 34: | Line 36: | ||
local insert = table.insert |
local insert = table.insert |
||
local concat = table.concat |
local concat = table.concat |
||
local find = |
local find = string.find |
||
local len = |
local len = string.len |
||
local sub = |
local sub = string.sub |
||
local rep = |
local rep = string.rep |
||
local listlevel = { '*', '**', '***', '****', '*****' } |
local listlevel = { '*', '**', '***', '****', '*****' } |
||
Line 51: | Line 53: | ||
if template == "index" then |
if template == "index" then |
||
template = "trope" |
template = "trope" |
||
crowners["trope"] = {} |
|||
mainpage = ":" .. page |
mainpage = ":" .. page |
||
page = page:gsub("Category:", "", 1) |
page = page:gsub("Category:", "", 1) |
||
Line 61: | Line 64: | ||
local subpage_list = split(allsptxt, "|") |
local subpage_list = split(allsptxt, "|") |
||
local tree = build_tree(subpage_list) |
local tree = build_tree(page, subpage_list) |
||
-- initialize result with Main link |
-- initialize result with Main link |
||
Line 107: | Line 110: | ||
local jsdata = '<div id="tm-data" style="display:none" ' |
local jsdata = '<div id="tm-data" style="display:none" ' |
||
.. 'data-toplevelpage="' .. page .. '" ' |
.. 'data-toplevelpage="' .. page .. '" ' |
||
.. 'data-wanted="' .. concat( missingout, " |
.. 'data-wanted="' .. concat( missingout, "	" ) .. '" ' |
||
.. 'data-templatetype="' .. template .. '" ' |
.. 'data-templatetype="' .. template .. '" ' |
||
.. '></div>' |
.. '></div>' |
||
Line 129: | Line 132: | ||
end |
end |
||
function sp.tree ( frame ) |
|||
local page = frame.args[1] or frame:callParserFunction('TOPLEVELPAGE') |
|||
local allsptxt = frame:callParserFunction('SUBPAGES', { page, sep = "|" }) |
|||
⚫ | |||
local subpage_list = split(allsptxt, "|") |
|||
local tree = build_tree(page, subpage_list) |
|||
if page:match("^Category:") then page = ":"..page end |
|||
return "; [["..page.."]]\n" .. build_list( tree, page..'/', 1 ) |
|||
⚫ | |||
⚫ | |||
local path_tree = { } |
local path_tree = { } |
||
local pagelenoffset = len(page) + 2 |
|||
for _, |
for _, fullpath in ipairs(subpage_list) do |
||
local path = sub(fullpath, pagelenoffset) |
|||
local list = split(path, '/') |
local list = split(path, '/') |
||
local lastdir = path_tree |
local lastdir = path_tree |
||
for i, dir in ipairs(list) do |
for i, dir in ipairs(list) do |
||
if |
if lastdir[dir] == nil then lastdir[dir] = { } end |
||
lastdir = lastdir[dir] |
|||
lastdir = lastdir[dir] |
|||
⚫ | |||
end |
end |
||
end |
end |
||
Line 151: | Line 166: | ||
local ul = {} |
local ul = {} |
||
⚫ | |||
local ordered_sp = {} |
|||
⚫ | |||
insert(ordered_sp, page) |
|||
end |
|||
table.sort(ordered_sp) |
|||
for i = 1, #ordered_sp do |
|||
local page = ordered_sp[i] |
|||
local branch = tree[page] |
|||
local li |
local li |
||
Latest revision as of 18:59, 27 July 2023
Documentation for this module may be created at Module:Subpages 3/doc
local sp = {}
local pageorder = {
["trope"] = {
"Analysis", "Haiku", "Headscratchers", "Image Links", "Laconic", "Playing With",
"Quotes", "Useful Notes"
},
["work"] = {
"Analysis", "Characters", "Laconic", "Recap", "Trivia", "Setting", "YMMV",
"Fridge", "Fanfic Recs", "Haiku", "Headscratchers", "Ho Yay", "Image Links",
"Memes", "Radar", "Quotes", "Reviews", "Source", "Useful Notes", "WMG"
},
["creator"] = {"YMMV", "Quotes", "Fanfic Recs", "Analysis", "Trivia", "WMG", "Image Links", "Haiku", "Laconic"}
}
local crowners = {
["trope"] = { "Animation", "Animated Films", "Anime", "Anime and Manga", "Board Games", "Comics", "Comic Books",
"Fan Works", "Fanfic", "Fanfiction", "Fan Fiction", "Film", "Folklore", "Literature",
"Live Action Television", "Live Action TV", "Machinima",
"Manga", "Manga and Anime", "Music", "Musicians", "New Media",
"Opera", "Professional Wrestling", "Puppet Shows", "Radio", "Tabletop Games", "Tabletop RPGs",
"Television", "TV",
"Theatre", "Theater", "Toys",
"Webcomics", "Video Games", "Visual Art", "Visual Novels",
"Web Original", "Web Animation", "Web Comics", "Websites",
"Western Animation", "Wikis", "Wrestling", "Other", "Real Life" },
["work"] = { "Awesome", "Funny", "Heartwarming", "Nightmare Fuel", "Tear Jerker" },
["creator"] = { "Awesome", "Funny", "Heartwarming", "Nightmare Fuel", "Tear Jerker" }
}
local crownername = {
["trope"] = "By Medium",
["work"] = "Crowners",
["creator"] = "Crowners"
}
-- localize functions
local insert = table.insert
local concat = table.concat
local find = string.find
local len = string.len
local sub = string.sub
local rep = string.rep
local listlevel = { '*', '**', '***', '****', '*****' }
function sp.menu ( frame )
local page = frame.args[1] or frame:callParserFunction('TOPLEVELPAGE')
local template = frame.args[2] or "work"
local wppage = frame.args[3] or page
local haswp = true --(frame.args[4] == '')
if wppage == "" then wppage = page end
-- create variant top level page variables
local mainpage = page;
if template == "index" then
template = "trope"
crowners["trope"] = {}
mainpage = ":" .. page
page = page:gsub("Category:", "", 1)
end
local pageslash = page..'/'
if pageorder[template] == nil then return "Module error: invalid template argument" end
local allsptxt = frame:callParserFunction('SUBPAGES', { page, sep = "|" })
local subpage_list = split(allsptxt, "|")
local tree = build_tree(page, subpage_list)
-- initialize result with Main link
local linkout = { '* [[' .. mainpage .. '|<span id="tm-main"></span>Main]]\n' }
local crownerout = { }
local otherout = { }
local missingout = { }
for _, subpage in ipairs(pageorder[template]) do
text = build_list( { [subpage] = tree[subpage] }, pageslash, 1 )
if text ~= '' then
insert(linkout, text)
else
insert(missingout, subpage)
end
tree[subpage] = nil
end
for _, subpage in ipairs(crowners[template]) do
text = build_list( { [subpage] = tree[subpage] }, pageslash, 2 )
if text ~= '' then
insert(crownerout, text)
else
insert(missingout, subpage)
end
tree[subpage] = nil
end
--deal with the leftover subpages
if next(tree) then
local ordered_keys = {}
for k in pairs(tree) do
insert(ordered_keys, k)
end
table.sort(ordered_keys)
for i = 1, #ordered_keys do
local subpage = ordered_keys[i]
text = build_list( { [subpage] = tree[subpage] }, pageslash, 2 )
if text ~= '' then
insert(otherout, text)
end
end
end
local jsdata = '<div id="tm-data" style="display:none" '
.. 'data-toplevelpage="' .. page .. '" '
.. 'data-wanted="' .. concat( missingout, "	" ) .. '" '
.. 'data-templatetype="' .. template .. '" '
.. '></div>'
local crowner_link = next(crownerout)
and '* [[#top|<span id="tm-' .. crownername[template].. '"></span>'..crownername[template]..']]\n'
or ''
local wikipedia_link = haswp
and "* [[wikipedia:" .. wppage .. '|<span id="tm-Wikipedia"></span>Wikipedia]]\n'
or ''
local all_sp_link = '* [[Special:PrefixIndex/' .. pageslash .. '|<span id="tm-Allothers"></span>All Subpages]]\n'
return concat(linkout)
.. crowner_link
.. concat(crownerout)
.. wikipedia_link
.. all_sp_link
.. concat(otherout)
.. '* <strong><span id="tm-New"></span>Create New</strong><ul id="tm-wantedpages"></ul>\n'
.. jsdata
end
function sp.tree ( frame )
local page = frame.args[1] or frame:callParserFunction('TOPLEVELPAGE')
local allsptxt = frame:callParserFunction('SUBPAGES', { page, sep = "|" })
local subpage_list = split(allsptxt, "|")
local tree = build_tree(page, subpage_list)
if page:match("^Category:") then page = ":"..page end
return "; [["..page.."]]\n" .. build_list( tree, page..'/', 1 )
end
function build_tree ( page, subpage_list )
local path_tree = { }
local pagelenoffset = len(page) + 2
for _, fullpath in ipairs(subpage_list) do
local path = sub(fullpath, pagelenoffset)
local list = split(path, '/')
local lastdir = path_tree
for i, dir in ipairs(list) do
if lastdir[dir] == nil then lastdir[dir] = { } end
lastdir = lastdir[dir]
end
end
return path_tree
end
function build_list ( tree, prefix, level )
local libase = listlevel[level] or rep('*', level)
local ul = {}
local ordered_sp = {}
for page in pairs(tree) do
insert(ordered_sp, page)
end
table.sort(ordered_sp)
for i = 1, #ordered_sp do
local page = ordered_sp[i]
local branch = tree[page]
local li
if level <= 2 then
li = libase .. " [["..prefix..page..'|<span id="tm-'..page..'"></span>'..page..']]\n'
else
li = libase ..' [['..prefix..page..'|'..page..']]\n'
end
insert(ul, li)
if next(branch) then
local nextprefix = (prefix..page..'/')
insert(ul, build_list(branch, nextprefix, level+1))
end
end
return concat(ul)
end
function split(str, sSeparator, nMax, bRegexp)
assert(sSeparator ~= '')
assert(nMax == nil or nMax >= 1)
local aRecord = {}
if len(str) > 0 then
local bPlain = not bRegexp
nMax = nMax or -1
local nField=1 nStart=1
local nFirst,nLast = find(str, sSeparator, nStart, bPlain)
while nFirst and nMax ~= 0 do
aRecord[nField] = sub(str, nStart, nFirst-1)
nField = nField+1
nStart = nLast+1
nFirst,nLast = find(str, sSeparator, nStart, bPlain)
nMax = nMax-1
end
aRecord[nField] = sub(str, nStart)
end
return aRecord
end
return sp