模組:Infobox artist/sandbox

--本模块用于执行 {{Infobox artist}} 及 {{配音员}} 模板
--后续会将 {{艺人}} 模板亦改为通过此模块执行,但艺人信息框模板结构较为复杂,故实现起来需要更长的时间。

local p = {}

local getArgs = require('Module:Arguments').getArgs

local infobox = require('Module:Infobox').infobox

local parameterListAR -- lazily initialized

local parameterListCV -- lazily initialized

local function getDataAR(args, idx)
	if not parameterListAR then
		parameterListAR = mw.loadData('Module:Infobox artist/parameterListAR')
	end
	for _, k in ipairs(parameterListAR[idx]) do
		if args[k] then return args[k] end
	end
end

local function getDataCV(args, idx)
	if not parameterListCV then
		parameterListCV = mw.loadData('Module:Infobox artist/parameterListCV')
	end
	for _, m in ipairs(parameterListCV[idx]) do
		if args[m] then	return args[m] end
	end
end

local function PageNameBase ()
	local pagename = require('Module:String').replace{ args = { 
		mw.title.getCurrentTitle().baseText,
		'%s+%b()$',
		'',
		'1',
		'false',
	} }
	return pagename
end

-- 颜色选择器、语言选择器等部件继续沿用既有的模板实现方式。
-- 等抽出时间再将其Lua化
local function getColor(frame)
	local args = getArgs(frame)
	return getColor(args)
end

local function getColor(args)
	local color = (mw.getCurrentFrame():expandTemplate({
		title = '藝人/color selector',
		args = {args[1]}
		} ))
	return color
end

local function getLanguage(frame)
	local args = getArgs(frame)
	return getLanguage(args)
end

local function getLanguage(args)
	local lang = (mw.getCurrentFrame():expandTemplate({
		title = '藝人/lang selector',
		args = {args[1]}
		} ))
	return lang
end

-- 生/卒年月日转换
local function dateofbirth(frame)
	local args = getArgs(frame)
	return dateofbirth(args)
end

local function dateofbirth(args)
	local dob = ''
	local count = 0
	
	if args.birthdate then
		dob = args.birthdate
	else
		if args.birthyear then
			count = count + 1
			if args.birthmonth then
				count = count + 1
				if args.birthday then
					count = count + 1
				end
			end
		end
		if count < 3 then
			if args.birthyear then
				dob = args.birthyear .. '年'
			end
			if args.birthmonth then
				dob = dob .. args.birthmonth .. '月'
				if args.birthday then
					dob = dob .. args.birthday .. '日'
				end
			end
		else
			if args.deathyear or args.deathmonth or args.deathday then
				dob = (mw.getCurrentFrame():expandTemplate({
					title = 'Birth date',
					args = {args.birthyear, args.birthmonth, args.birthday}
					} ))
			else
				dob = (mw.getCurrentFrame():expandTemplate({
					title = 'Birth date and age',
					args = {args.birthyear, args.birthmonth, args.birthday}
					} ))
			end
		end
	end
	return dob
end

local function dateofdeath(frame)
	local args = getArgs(frame)
	return dateofdeath(args)
end

local function dateofdeath(args)
	local dod = ''
	local count = 0
	
	if args.deathdate then
		dod = args.deathdate
	else
		if args.deathyear then
			count = count + 1
			if args.deathmonth then
				count = count + 1
				if args.deathday then
					count = count + 1
					if args.birthyear then
						count = count + 1
						if args.birthmonth then
							count = count + 1
							if args.birthday then
								count = count + 1
							end
						end
					end
				end
			end
		end
		if count < 6 then
			if args.deathyear then
				dod = args.deathyear .. '年'
			end
			if args.deathmonth then
				dod = dod .. args.deathmonth .. '月'
				if args.deathday then
					dod = dod .. args.deathday .. '日'
				end
			end
		else
			dod = (mw.getCurrentFrame():expandTemplate({
				title = 'Death date and age',
				args = {args.deathyear, args.deathmonth, args.deathday, args.birthyear, args.birthmonth, args.birthday}
				} ))
		end
	end
	return dod
end

-- 维基数据图片检测
local function renderTrackingPhotos(frame)
	local args = getArgs(frame)
	return renderTrackingPhotos(args)
end

local function renderTrackingPhotos(args)
	local cat = (mw.getCurrentFrame():expandTemplate({
		title = 'Wikidata image',
		args = {args[1]}
		} ))
	return cat
end

function p.artist(frame)
	if not parameterListAR then
		parameterListAR = mw.loadData('Module:Infobox artist/parameterListAR')
	end
	local args = getArgs(frame)
	return p._artist(args)
end

function p._artist(args)
	-- 艺术家信息框模板。
	-- --请将新增参数加于模块:Infobox artist/parameterListAR
	local list = {}
	local cont = 5
	
	list.bodyclass = 'vcard plainlist'
	
	list.above = (mw.getCurrentFrame():expandTemplate({ 
		title = 'Br separated entries', 
		args = { 
			(getDataAR(args, 'honorific_prefix') and
    			'<span class="honorific-prefix" style="font-size:small; font-weight:normal;">' .. getDataAR(args, 'honorific_prefix') .. '</span>' or ''),
    		'<span class=fn">' .. (getDataAR(args, 'name') or PageNameBase() ) .. '</span>',
		 	(getDataAR(args, 'honorific_suffix') and
    			'<span class="honorific-suffix" style="font-size:small; font-weight:normal;">' .. getDataAR(args, 'honorific_suffix') .. '</span>' or ''),
		} }))
	
	list.abovestyle = 'font-size: 120%;  '
	list.labelstyle = 'white-space:nowrap;'
	
	list.image = require('Module:InfoboxImage').InfoboxImage{ args = { 
		image = getDataAR(args, 'image'),
		size = getDataAR(args, 'image_size'),
		sizedefault = 'frameless',
		upright = '1',
		alt = getDataAR(args, 'alt'),
		suppressplaceholder = yes,
	} }
	list.caption = list.image and getDataAR(args, 'caption')
	
	--list.header1 = '艺术家'
	
	list.label2 = '原文名'
	list.data2 = (getDataAR(args, 'native_name') and
		'<span class="nickname"' .. (getDataAR(args, 'native_name_lang') and ' lang="' .. getDataAR(args, 'native_name_lang') .. '" "xml:lang="' .. getDataAR(args, 'native_name_lang') .. '"' or '') .. '>-{' .. getDataAR(args, 'native_name') .. '}-</span>' or '')
	
	list.label3 = '出生'
	list.data3 = (mw.getCurrentFrame():expandTemplate({
		title = 'Br separated entries',
		args = {
			(getDataAR(args, 'birth_name') and
				'<span class="nickname">' .. getDataAR(args, 'birth_name') .. '</span>' or ''),
			getDataAR(args, 'birth_date'),
			(getDataAR(args, 'birth_place') and
				'<span class="birthplace">' .. getDataAR(args, 'birth_place') .. '</span>' or ''),
			} } ))
	
	list.label4 = '逝世'
	list.data4 = (mw.getCurrentFrame():expandTemplate({
		title = 'Br separated entries',
		args = {
			getDataAR(args, 'death_date'),
			(getDataAR(args, 'death_place') and
				'<span class="deathplace">' .. getDataAR(args, 'death_place') .. '</span>' or ''),
			} } ))
	
	list.label5 = '墓地'
	list.data5 = (mw.getCurrentFrame():expandTemplate({
		title = 'Br separated entries',
		args = {getDataAR(args, 'resting_place'), getDataAR(args, 'resting_place_coordinates')}
		} ))
	
	for i, k in ipairs(parameterListAR) do
		local data = getDataAR(args, i)
		if data then
			cont = cont + 1
			list['data'..cont] = data
			list['label'..cont] = k.label
			list['header'..cont] = k.header
		end
	end
	
	list.class1 = 'title role'
	list.class5 = 'label'
	list.class6 = 'category'
	list.class11 = 'category'
	list.class12 = 'category'
	list.class14 = 'note'
	list.class15 = 'org'
	list.rowclass17 = 'note'
	list.class18 = 'url'
	
	return infobox(list) .. renderTrackingPhotos( {getDataAR(args, 'image')} )
end

function p.CV(frame)
	if not parameterListCV then
		parameterListCV = mw.loadData('Module:Infobox artist/parameterListCV')
	end
	local args = getArgs(frame)
	return p._CV(args)
end

function p._CV(args)
	-- 声优模板。
	-- --请将新增参数加于模块:Infobox artist/parameterListCV
	local list = {}
	local cont = 12
	
	list.child = (getDataCV(args, 'embed') and getDataCV(args, 'embed'):lower() or '')
	list.decat = 'yes'
	
	list.bodyclass = 'vcard plainlist'
	
	if list.child == 'yes' then
		list.title = '\'\'\'配音生涯\'\'\''
	end
	
	list.aboveclass = 'fn'
	list.above = (getDataCV(args, 'name') or PageNameBase() )
	
	list.abovestyle = 'font-size: 120%; background: ' .. getColor( {'配音员'} )
	if list.child ~= 'yes' then
		list.headerstyle = 'background: ' .. getColor( {'配音员'} )
	end
	list.labelstyle = 'white-space:nowrap;'
	
	list.image = require('Module:InfoboxImage').InfoboxImage{ args = { 
		image = getDataCV(args, 'image'),
		size = getDataCV(args, 'image_size'),
		sizedefault = 'frameless',
		upright = '1',
		alt = getDataCV(args, 'alt'),
		suppressplaceholder = yes,
	} }
	list.caption = list.image and getDataCV(args, 'caption')
	
	if list.child ~= 'yes' then
		list.header1 = '-{zh-hans:配音演员;zh-hant:配音員;}-'
	end
	
	list.label2 = '本名'
	list.data2 = getDataCV(args, 'real_name')
	
	list.label3 = '原文名'
	list.data3 = (getDataCV(args, 'native_name') and
		'<span class="nickname"' .. (getDataCV(args, 'native_name_lang') and ' lang="' .. getLanguage( {getDataCV(args, 'native_name_lang')} ) .. '" "xml:lang="' .. getLanguage( {getDataCV(args, 'native_name_lang')} ) .. '"' or '') .. '>-{' .. getDataCV(args, 'native_name') .. '}-</span>' or '')
	
	list.label4 = '罗马拼音'
	list.data4 = (getDataCV(args, 'romanized_name') and
		'<span class="nickname" lang="en" xml:lang="en">' .. getDataCV(args, 'romanized_name') .. '</span>' or '')
	
	list.label5 = '英文名'
	list.data5 = (getDataCV(args, 'english_name') and
		'<span class="nickname" lang="en" xml:lang="en">' .. getDataCV(args, 'english_name') .. '</span>' or '')
	
	list.label6 = '昵称'
	list.data6 = getDataCV(args, 'nickname')
	
	list.label7 = '艺名'
	list.data7 = getDataCV(args, 'other_name')
	
	list.label8 = '国籍'
	list.data8 = getDataCV(args, 'nationality')
	
	list.label9 = '籍贯'
	list.data9 = getDataCV(args, 'hometown')
	
	list.label10 = '出生'
	list.data10 = (mw.getCurrentFrame():expandTemplate({
		title = 'Br separated entries',
		args = {
			(getDataCV(args, 'birth_name') and
				'<span class="nickname">' .. getDataCV(args, 'birth_name') .. '</span>' or ''),
			dateofbirth( {
				birthyear = getDataCV(args, 'birthyear'),
				birthmonth = getDataCV(args, 'birthmonth'),
				birthday = getDataCV(args, 'birthday'),
				deathyear = getDataCV(args, 'deathyear'),
				deathmonth = getDataCV(args, 'deathmonth'),
				deathday = getDataCV(args, 'deathday')
				} ),
			(getDataCV(args, 'birth_place') and
				'<span class="birthplace">' .. getDataCV(args, 'birth_place') .. '</span>' or ''),
			} } ))
	
	list.label11 = '出身地'
	list.data11 = getDataCV(args, 'origin_place')
	
	list.label12 = '逝世'
	list.data12 = (mw.getCurrentFrame():expandTemplate({
		title = 'Br separated entries',
		args = {
			dateofdeath( {
				birthyear = getDataCV(args, 'birthyear'),
				birthmonth = getDataCV(args, 'birthmonth'),
				birthday = getDataCV(args, 'birthday'),
				deathyear = getDataCV(args, 'deathyear'),
				deathmonth = getDataCV(args, 'deathmonth'),
				deathday = getDataCV(args, 'deathday')
				} ),
			(getDataCV(args, 'death_place') and
				'<span class="deathplace">' .. getDataCV(args, 'death_place') .. '</span>' or ''),
			} } ))
	
	for i, m in ipairs(parameterListCV) do
		local data = getDataCV(args, i)
		if data then
			cont = cont + 1
			list['data'..cont] = data
			list['label'..cont] = m.label
			list['header'..cont] = m.header
		end
	end
	
	cont = cont + 1
	list['header'..cont] = (getDataCV(args, 'years_active') and '活动' or (getDataCV(args, 'debut_work') and '活动' or (getDataCV(args, 'famous_work') and '活动' or '' ) ) )
	
	cont = cont + 1
	list['label'..cont] = '活動時期'
	list['data'..cont] = getDataCV(args, 'years_active')
	
	cont = cont + 1
	list['label'..cont] = '出道作'
	list['data'..cont] = getDataCV(args, 'debut_work')
	
	cont = cont + 1
	list['label'..cont] = '代表作'
	list['data'..cont] = getDataCV(args, 'famous_work')
	
	cont = cont + 1
	list['label'..cont] = '网站'
	list['data'..cont] = getDataCV(args, 'website')
	
	cont = cont + 1
	list['label'..cont] = '其他'
	list['data'..cont] = getDataCV(args, 'footnotes')
	
	cont = cont + 1
	list['data'..cont] = getDataCV(args, 'misc')
	
	list.class1 = 'title role'
	list.class2 = 'nickname'
	list.class6 = 'nickname'
	list.class7 = 'nickname'
	list.class8 = 'category'
	list.class18 = 'category'
	list.class24 = 'url'
	list.class25 = 'note'
	
	if list.child ~= 'yes' then
		list.belowclass = 'noprint'
		list.below = '[[配音員|-{zh-hans:配音演员;zh-hant:配音員;}-]]:[[Template:配音員|模板]] &#124; [[:Category:配音員|分类]]'
		list.belowstyle = 'border-top:1px solid #aaa; padding-top:0.2em; text-align:right; font-size:80%;'
		return infobox(list) .. renderTrackingPhotos( {getDataCV(args, 'image')} )
	else
		return infobox(list)
	end
end

return p