{{i}} Документація модуля[перегляд] [редагувати] [історія] [очистити кеш]

Модуль шаблону {{portal bar}}. Відображає горизонтальну стрічку порталів.

Використання ред.

{{#invoke:Portal bar|main|''<портал 1>''|''<портал 2>''|...|border=''no''}}
  • Позиційні параметри — назви порталів для відображення.
  • |border= — якщо значення |border= дорівнює no, n, false або 0, стрічка порталів буде виведена без абрису.

Приклади ред.

  • {{#invoke:portal bar|main|Мистецтво|Наука|Література}}

дає:

  • {{#invoke:portal bar|main|Мистецтво|Наука|Література|border=no}}

дає:

Інші приклади: en:Template:Portal bar/testcases.

Зображення ред.

Модуль використовує Модуль:Portal для отримання іконок порталів. Інструкції щодо того, як додавати, змінювати або видаляти іконки порталів, див. тут: en:Module:Portal#Image.

Див. також ред.

Цей модуль містить код, запозичений з модуля «Portal bar» англійської Вікіпедії.

Переклад
-- This module implements {{portal bar}}.

require('Модуль:No globals')

local portalModule = require('Модуль:Портал')
local getImageName = portalModule.image
local checkPortals = portalModule._checkPortals
local processPortalArgs = portalModule._processPortalArgs
local yesno = require( 'Модуль:Yesno' )
local getArgs = require('Модуль:Arguments').getArgs
local p = {}

-- determine whether we're being called from a sandbox
local isSandbox = mw.getCurrentFrame():getTitle():find('пісочниця', 1, true)
local sandbox = isSandbox and '/пісочниця' or ''

local function sandboxVersion(s)
	return isSandbox and s.."-пісоч" or s
end

-- Builds the portal bar used by {{portal bar}}.
function p._main( portals, args )
	
	-- check for sensible args
	args = type(args) == "table" and args or {}
	
	-- Normalize arguments
	for key, default in pairs({border=true,redlinks=false,tracking=true}) do
		if args[key] == nil then args[key] = default end
		args[key] = yesno(args[key], default)
	end

	local nav = mw.html.create( 'div' )
		:addClass(sandboxVersion('portal-bar'))
		:addClass( 'noprint metadata noviewer' )
		:attr( 'role', 'navigation' )
		:attr( 'aria-label' , 'Portals' )
		:addClass(sandboxVersion(args.border and 'portal-bar-bordered' or 'portal-bar-unbordered'))
	
	local trackingCat = ''
	-- Allow any number of portals
	args.minPortals = 0
	args.maxPortals = -1
	-- Check to see whether there are redlinks, filter out unless args.redlink is true
	portals, trackingCat = checkPortals(portals, args)
	nav:wikitext(trackingCat)
	if #portals == 0 then
		return trackingCat
	end

	local header = nav:tag('span')
	header:addClass(sandboxVersion('portal-bar-header'))
	header:wikitext('[[Вікіпедія:Вміст/Портали|Портал]]')
	if #portals > 1 then
		header:wikitext('и')
	end
	header:wikitext(':')
	local container = nav:tag('div')
	container:addClass(sandboxVersion('portal-bar-content'))
	for _, portal in ipairs( portals ) do
		container
			:tag( 'div' )
			:addClass(sandboxVersion('portal-bar-item'))
				:tag( 'span' )
					:addClass(sandboxVersion('portal-bar-logo'))
					:wikitext( string.format(
						'[[Файл:%s|21x19px|alt=]]', getImageName{ portal }
					) )
					:done()
				:tag('span')
					:addClass(sandboxVersion('portal-bar-link'))
					:wikitext( string.format('[[Портал:%s|%s]]', portal, portal))
	end
	
	local styleFile = 'Модуль:Portal bar'..sandbox..'/styles.css'
	return mw.getCurrentFrame():extensionTag{
		name = 'templatestyles', args = { src = styleFile }
	} .. tostring( nav ) 
end

-- Processes external arguments and sends them to the other functions.
function p.main( frame )
	local origArgs = getArgs(frame)
	local portals, args = processPortalArgs(origArgs)
	return p._main( portals, args )
end

return p