Jump to content
Wikipedia The Free Encyclopedia

Module:Team roster navbox

From Wikipedia, the free encyclopedia
Module documentation[view] [edit] [history] [purge]
[画像:Protected] 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 &nbsp; 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.)

The above documentation is transcluded from Module:Team roster navbox/doc. (edit | history)
Editors can experiment in this module's sandbox (edit | diff) and testcases (create) pages.
Subpages of this module.

 -- 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;', '#'), '&#35;', '#'), ';')
	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

AltStyle によって変換されたページ (->オリジナル) /