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

来自Arcaea中文维基
(fixed)
(pack)
 
(未显示同一用户的12个中间版本)
第1行: 第1行:
local p={}
local p = { single = { idx = -100, name = "Memory Archive" } }
local W=mw
local plst = mw.text.jsonDecode(mw.getCurrentFrame():expandTemplate { title = "packlist" }).packs
function LoadJson(filename)
local special = { base = true, omatsuri = true, observer = true }
   return W.text.jsonDecode(W.getCurrentFrame():expandTemplate{ title = filename })
for i, v in ipairs(plst) do
end
local co = v.custom_banner and not special[v.id]
 
local name = v.name_localized.en
local packPrior,packName=(function ()
if co then name = name .. " Collaboration" end
local huge=16383
if (p[v.pack_parent or ""] or p.single).name:find " Collaboration" then
local P,N={single = huge},{single = 'Memory Archive'}
name = p[v.pack_parent].name .. " - " .. name
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[tmp[a].id]~=packPrior[tmp[b].id] then
return packPrior[tmp[a].id]<packPrior[tmp[b].id]
else
return tmp[a].date<tmp[b].date
end
end)
return LS,LST
end)()
 
function p.main(frames)
local chart=''
for i,v in ipairs(songList) do
chart=chart..songLines[v]
end
end
return chart
p[v.id] = { idx = i, name = name }
end
end
return p
return p

2022年9月16日 (五) 15:30的最新版本

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

local p = { single = { idx = -100, name = "Memory Archive" } }
local plst = mw.text.jsonDecode(mw.getCurrentFrame():expandTemplate { title = "packlist" }).packs
local special = { base = true, omatsuri = true, observer = true }
for i, v in ipairs(plst) do
	local co = v.custom_banner and not special[v.id]
	local name = v.name_localized.en
	if co then name = name .. " Collaboration" end
	if (p[v.pack_parent or ""] or p.single).name:find " Collaboration" then
		name = p[v.pack_parent].name .. " - " .. name
	end
	p[v.id] = { idx = i, name = name }
end
return p