Module:沙盒/盐棋/Sandbox2:修订间差异

来自Arcaea中文维基
(i?)
(debug)
第1行: 第1行:
local p={}
local p={}
local W=mw
local W=mw
local juh=0
function LoadJson(filename)
function LoadJson(filename)
    return W.text.jsonDecode(W.getCurrentFrame():expandTemplate{ title = filename })
    return W.text.jsonDecode(W.getCurrentFrame():expandTemplate{ title = filename })
第87行: 第88行:
table.sort(LST,function (a, b)
table.sort(LST,function (a, b)
if packPrior[a]~=packPrior[b] then
if packPrior[a]~=packPrior[b] then
return packPrior[a]<packPrior[b]
juh=juh+1
return packPrior[a]<packPrior[b]
else
else
return tmp[a].date<tmp[b].date
return tmp[a].date<tmp[b].date
第97行: 第99行:
function p.main(frames)
function p.main(frames)
local chart=''
local chart=''
for i,v in pairs(songList) do
-- for i,v in pairs(songList) do
chart=chart..songLines[v]
-- chart=chart..songLines[v]
end
-- end
return chart
-- return chart
return W.text.jsonEncode({list=songList, notsam=juh},W.text.JSON_PRETTY)
end
end


return p
return p

2022年5月11日 (三) 16:50的版本

可在Module:沙盒/盐棋/Sandbox2/doc创建此模块的帮助文档

local p={}
local W=mw
local juh=0
function LoadJson(filename)
    return W.text.jsonDecode(W.getCurrentFrame():expandTemplate{ title = filename })
end

local packPrior,packName=(function ()
	local huge=16383
	local P,N={single = huge},{single = 'Memory Archive'}
	local contest={['base']=true,['observer']=true,['omatsuri']=true}
	local conbine=function(rt,lf)return rt..'#'..rt..' - '..lf..'|'..rt..' - '..lf end
	for i,v in ipairs(LoadJson("packlist").packs) do
		P[v.id]=i
		N[v.id]=v.name_localized.en
		if v.pack_parent then
			P[v.id]=P[v.pack_parent]
			N[v.id]=conbine(N[v.pack_parent],N[v.id])
		elseif v.custom_banner and not contest[v.id] then
			N[v.id]=N[v.id]..' Collaboration'
		end
	end
	for i,v in ipairs(LoadJson("packlist NS").packs) do
		if not N[v.id] and v.pack_parent then--single-append
			P[v.id]=P[v.pack_parent]
			N[v.id]=conbine(N[v.pack_parent],v.name_localized.en)
		end
	end
	return P,N
end)()

local songLines,songList=(function ()
	local tmp,LS,LST={},{},{}
	local mbIcon,nsIcon='[[文件:Icon Smartphone.png|16px|link=曲目列表 (移动版)]]','[[文件:Icon Nintendo switch.png|16px|link=曲目列表 (Nintendo Switch版)]]'
	local NS_byd_set={['tempestissimo']=true}
	local display={['ifi']='#1f1e33',['aiueoon']='AI[UE]OON',['quon']='Quon (Feryquitous)',['quonwacca']='Quon (DJ Noriken)'}
	for i,v in ipairs(LoadJson("songlist").songs) do
		v.__plat={mbIcon}
		tmp[v.id]=v
	end
	for i,v in pairs(display) do
		tmp[i].__title=v
		tmp[i].__titleLink=v..'|'..tmp[i].title_localized.en
	end
	for i,v in ipairs(LoadJson("songlist NS").songs) do
		if tmp[v.id] then
			tmp[v.id].__plat[2]=nsIcon
		else
			v.__plat={nsIcon}
			tmp[v.id]=v
		end
	end
	for i,v in pairs(tmp) do
		table.insert(LST,i)
		local page=W.title.new(v.__title or v.title_localized.en):getContent()
		local dur=page:match("时长%s*=%s*0?(%d:%d%d)")or'nilErr'--test
		local plat,bpm,rate='',v.bpm,''
		local mark=W.getCurrentFrame():expandTemplate{title='仅',args={'移动版','','图片角标'}}
		if not tonumber(bpm) then
			bpm='data-sort-value='..v.bpm_base..'|'..bpm
		end
		for j,d in ipairs(v.__plat) do
			plat=plat..d
		end
		for j,d in ipairs(v.difficulties) do
			rate=rate..'||'..d.rating
			if d.ratingPlus then
				rate=rate..'+'
			end
		end
		if v.difficulties[4] then
			if not NS_byd_set[v.id] then
				rate=rate..mark
			end
		else
			rate=rate..'||/'
		end
		page=nil
		LS[i]='|'..plat..'\n|[[文件:Songs '..v.id..'.jpg|75px]]'
		..'\n|[['..(v.__titleLink or v.title_localized.en)..']]'
		..'\n|'..v.artist
		..'\n|[['..packName[v.set]..']]'
		..'\n|'..bpm
		..'\n|0'..dur
		..'\n'..rate:sub(2)
		..'\n|-\n'
	end
	table.sort(LST,function (a, b)
		if packPrior[a]~=packPrior[b] then
			juh=juh+1
			return packPrior[a]<packPrior[b]
		else
			return tmp[a].date<tmp[b].date
		end
	end)
	return LS,LST
end)()

function p.main(frames)
	local chart=''
	-- for i,v in pairs(songList) do
	-- 	chart=chart..songLines[v]
	-- end
	-- return chart
	return W.text.jsonEncode({list=songList, notsam=juh},W.text.JSON_PRETTY)
end

return p