模块:Main

来自维阿百科
跳转至: 导航搜索

此模块的文档可以在模块:Main/doc创建

--[[
-- This module produces a link to a main article or articles. It implements the
-- template {{main}}.
-- 
-- If the module is used in category or category talk space, it produces "The
-- main article for this category is xxx". Otherwise, it produces
-- "Main article: xxx".
--]]

local mHatnote = require('Module:Hatnote')
local mHatlist = require('Module:Hatnote list')
local mArguments -- lazily initialise
local p = {}

function p.main(frame)
	mArguments = require('Module:Arguments')
	local args = mArguments.getArgs(frame, {parentOnly = true})
	local pages = {}
	for k, v in pairs(args) do
		if type(k) == 'number' then
			local display = args['label ' .. k] or args['l' .. k]
			local page = display and
				string.format('%s|%s', string.gsub(v, '|.*$', ''), display) or v
			pages[#pages + 1] = page
		end
	end
	if #pages == 0 and mw.title.getCurrentTitle().namespace == 0 then
		-- 本地化注意
		return mHatnote.makeWikitextError(
			'没有指定条目名',
			'Template:Main#错误',
			args.category
		)
	end
	local options = {
		selfref = args.selfref
	}
	return p._main(pages, options, frame)
end

function p._main(args, options, frame)
	-- Get the list of pages. If no first page was specified we use the current
	-- page name.
	local currentTitle = mw.title.getCurrentTitle()
	if #args == 0 then args = {currentTitle.text} end
	local firstPage = string.gsub(args[1], '|.*$', '')
	-- Find the pagetype.
	-- 本地化注意
	local pageType = mHatnote.findNamespaceId(firstPage) == 0 and '条目' or '页面'
	-- Make the formatted link text
	list = mHatlist.andList(args, true)
	-- Build the text.
	local isPlural = #args > 1
	local mainForm
	local curNs = currentTitle.namespace
	-- 本地化注意
	if (curNs == 14) or (curNs == 15) then --category/talk namespaces
		mainForm = '此[[Wikipedia:頁面分類|分类]]的主%s是%s'
	else
		mainForm = '主%s:%s'
	end
	local text = string.format(mainForm, pageType, list)
	-- Process the options and pass the text to the _rellink function in
	-- [[Module:Hatnote]].
	--[[options = options or {}
	-- 本地化注意
	local hnOptions = {
		extraclasses = 'noprint relarticle mainarticle', --追加noprint的css类
		selfref = options.selfref
	}
	return mHatnote._hatnote(text, hnOptions)]]
    return frame:expandTemplate{
    	title="rellink",
    	args={text,extraclasses='noprint relarticle mainarticle'}
    } --没想到Hatnote与{{rellink}}实现不同,替代品
end

return p