Module:Team roster navbox: Difference between revisions
From Thetacola Wiki
Jump to navigationJump to search
en>Frietjes (support for groupNstyle) |
m (1 revision imported) |
(No difference)
|
Latest revision as of 00:22, 15 August 2022
File:Full-protection-shackle.svg | This module is subject to page protection. It is a highly visible module in use by a very large number of pages, or is substituted very frequently. Because vandalism or mistakes would affect many pages, and even trivial editing might cause substantial load on the servers, it is protected from editing. |
This module is used to implement {{Team roster navbox}}
, a helper template used to implement the individual team roster navboxes for the Major League Baseball teams.
At present, it parses any list<number> arguments to the template and replaces spaces in each list item with in order to prevent wrapping. It then calls Module:Navbox._navbox() to create the navbox. (Note the preprocessing done by Module::Navbox.navbox() has not been copied to this module and so is skipped.)
-- This module implements {{team roster navbox}} local me = { } local Navbox = require('Module:Navbox') local getArgs -- lazily initialized local function colorlinks(v, s) if v and v ~= '' and s and s ~= '' then if not mw.ustring.match(v, '<span style') then v = mw.ustring.gsub(v, '%[%[([^%[%]|]*)%]%]', '[[%1|<span style="' .. s .. '>%1</span>]]') v = mw.ustring.gsub(v, '%[%[([^%[%]|]*)|([^%[%]|]*)%]%]', '[[%1|<span style="' .. s .. '>%2</span>]]') end end return v end local function extractstyle(v) local r = '' local slist = mw.text.split(mw.ustring.gsub(mw.ustring.gsub(v or '', '&#[Xx]23;', '#'), '#', '#'), ';') for k = 1,#slist do local s = slist[k] if s:match('^[%s]*background') or s:match('^[%s]*color') then r = r .. s .. ';' end end return r end function me.generateRosterNavbox(frame) if not getArgs then getArgs = require('Module:Arguments').getArgs end local args = { } local parentArgs = getArgs(frame) -- Default is to nowrap items args['nowrapitems'] = 'yes' -- Massage the styles for coloring the links local basestyle = extractstyle(parentArgs['basestyle'] or '') local titlestyle = extractstyle(parentArgs['titlestyle'] or '') local abovestyle = extractstyle(parentArgs['abovestyle'] or '') local groupstyle = extractstyle(parentArgs['groupstyle'] or '') local belowstyle = extractstyle(parentArgs['belowstyle'] or '') if basestyle ~= '' then titlestyle = basestyle .. ';' .. titlestyle abovestyle = basestyle .. ';' .. abovestyle groupstyle = basestyle .. ';' .. groupstyle belowstyle = basestyle .. ';' .. belowstyle end -- Color links before passing them to the Navbox helper function for argName, value in pairs(parentArgs) do if value ~= '' then if type(argName) == 'string' then if argName == 'title' then value = colorlinks(value, titlestyle) elseif argName == 'above' then value = colorlinks(value, abovestyle) elseif mw.ustring.find(argName, '^group[0-9][0-9]*$') then if parentArgs[argName .. 'style'] then value = colorlinks(value, extractstyle(groupstyle .. ';' .. parentArgs[argName .. 'style'])) else value = colorlinks(value, groupstyle) end elseif argName == 'below' then value = colorlinks(value, belowstyle) end args[argName] = value end end end -- Note Navbox.navbox() has a kludge to order the parent frame's args -- into a specific order. For now, this is omitted from this module. return Navbox._navbox(args) end -- function me.generateRosterNavbox return me