Module:沙盒/Economy666/SongCollectionMulti:修订间差异
Economy666(讨论 | 贡献) 无编辑摘要 |
Economy666(讨论 | 贡献) (eden) |
||
第55行: | 第55行: | ||
-- local plat = 'mobile' | -- local plat = 'mobile' | ||
-- 不对song下述提及的字段存在性做检验 | -- 不对song下述提及的字段存在性做检验 | ||
local diffId = {['edenwacca']='eden'} | |||
local multi_song={} | local multi_song={} | ||
第73行: | 第75行: | ||
multi_song[song.id] = song | multi_song[song.id] = song | ||
end | end | ||
end | |||
for _,v in pairs(diffId) do | |||
multi_song[v] = nil | |||
end | end | ||
第88行: | 第93行: | ||
local display_plat = '' | local display_plat = '' | ||
if mobile_id[ | local NSid = id | ||
if mobile_id[id] then | |||
display_plat = display_plat .. '[[文件:Icon Smartphone.png|16px|link=曲目列表 (移动版)]]' | display_plat = display_plat .. '[[文件:Icon Smartphone.png|16px|link=曲目列表 (移动版)]]' | ||
end | end | ||
if ns_id[ | if ns_id[id] then | ||
display_plat = display_plat .. '[[文件:Icon Nintendo switch.png|16px|link=曲目列表 (Nintendo Switch版)]]' | |||
elseif diffId[id] then | |||
display_plat = display_plat .. '[[文件:Icon Nintendo switch.png|16px|link=曲目列表 (Nintendo Switch版)]]' | display_plat = display_plat .. '[[文件:Icon Nintendo switch.png|16px|link=曲目列表 (Nintendo Switch版)]]' | ||
NSid = diffId[id] | |||
end | end | ||
if display_plat == '' then | if display_plat == '' then | ||
第118行: | 第127行: | ||
local pack_main = string.gsub(trans.packName[song.set] or packItem['name'], cc, ccl) | local pack_main = string.gsub(trans.packName[song.set] or packItem['name'], cc, ccl) | ||
local pack_md = string.gsub(pack_main, ccl, ccd) | local pack_md = string.gsub(pack_main, ccl, ccd) | ||
if mobile_id[id] and ns_id[ | if mobile_id[id] and ns_id[NSid] then | ||
packItem_ns = mad.packQueryWrap(ns_song[ | packItem_ns = mad.packQueryWrap(ns_song[NSid].set, 'ns') | ||
local pack_ns = string.gsub(trans.packName[ns_song[ | local pack_ns = string.gsub(trans.packName[ns_song[NSid].set] or packItem_ns['name'], cc, ccl) | ||
local pack_nd = string.gsub(pack_ns, ccl, ccd) | local pack_nd = string.gsub(pack_ns, ccl, ccd) | ||
if pack_ns == pack_main then | if pack_ns == pack_main then |
2024年6月29日 (六) 13:11的版本
可在Module:沙盒/Economy666/SongCollectionMulti/doc创建此模块的帮助文档
local mad = require 'Module:AnotherData'
local lang = mw.language.getContentLanguage()
local frame = mw.getCurrentFrame()
local p = {}
local dates, versionNames = {}, {}
local function verQuery(sec)
local date = tonumber(lang:formatDate('ymd', '@' .. sec)) - 1
if date > dates[#dates] then return '@' end
local l, r = 1, #dates
while l < r do
local m = math.floor((l + r) / 2)
if dates[m] < date then
l = m + 1
else
r = m
end
end
return versionNames[l]
end
local function otherTitles(song)
local res = {}
local titleJa = song.title_localized.ja
if titleJa then table.insert(res, ('<span lang="ja">-{%s}-</span>'):format(titleJa)) end
table.insert(res, song.title_localized['zh-Hans'])
for _, diff in ipairs(song.difficulties) do
if diff.title_localized then
table.insert(res, diff.title_localized.en .. ' ' .. mad.color {
rc = diff.ratingClass,
txt = ('[%s]'):format(({[3] = 'Beyond'})[diff.ratingClass])
})
end
end
return res
end
local cal = mw.loadJsonData 'Template:ComplexArtistsList.json'
local trans = mw.loadJsonData 'Template:Transition.json'
local function link(l, d)
if d then
return '[[' .. l .. '|' .. d .. ']]'
else
return '[[' .. l .. ']]'
end
end
local onlyMobile = frame:expandTemplate{title = '仅', args = {'移动版', '', '图片角标'}}
local onlyNS = frame:expandTemplate{title = '仅', args = {'NS版', '', '图片角标'}}
local sectionCode = {unknown = 0, free = 1, archive = 2, mainstory = 3, sidestory = 4, collab = 5, single = 6}
local function main(args, durArgs)
local view = {}
-- local plat = 'mobile'
-- 不对song下述提及的字段存在性做检验
local diffId = {['edenwacca']='eden'}
local multi_song={}
local ns_song={}
local multi_id={}
local mobile_id={}
local ns_id={}
for _, song in ipairs(mad.listOf('songs', 'mobile')) do
mobile_id[song.id] = 1
multi_id[song.id] = 1
multi_song[song.id] = song
end
for _, song in ipairs(mad.listOf('songs', 'ns')) do
ns_id[song.id] = 1
ns_song[song.id] = song
if not multi_id[song.id] then
multi_id[song.id] = 1
multi_song[song.id] = song
end
end
for _,v in pairs(diffId) do
multi_song[v] = nil
end
for _, song in pairs(multi_song) do
local id = song.id
local packItem = mad.packQueryWrap(song.set, 'mobile')
local data = setmetatable({}, {__index = table})
local function input(...) return args[table.concat({id, ...}, '.')] end
if id ~= 'lasteternity' then
table.insert(view, {
data = data,
sort = {sectionCode[packItem['section']], packItem['numero'], song.date}
})
end
local display_plat = ''
local NSid = id
if mobile_id[id] then
display_plat = display_plat .. '[[文件:Icon Smartphone.png|16px|link=曲目列表 (移动版)]]'
end
if ns_id[id] then
display_plat = display_plat .. '[[文件:Icon Nintendo switch.png|16px|link=曲目列表 (Nintendo Switch版)]]'
elseif diffId[id] then
display_plat = display_plat .. '[[文件:Icon Nintendo switch.png|16px|link=曲目列表 (Nintendo Switch版)]]'
NSid = diffId[id]
end
if display_plat == '' then
display_plat = '无'
end
data:insert(display_plat)
data:insert(id)
-- otherTitles
data:insert(input '标题' or table.concat({'[[' .. mad.linkTitle(song) .. ']]', unpack(otherTitles(song))}, '<br>'))
local artist = cal[string.gsub(song.artist, ' ' , '') ]
if not artist then
artist = mw.ustring.gsub(
song.artist, '[一-龠ぁ-ゔァ-ヴー々〆〤ヶ]+',
function(v) return ('<span lang="ja">-{%s}-</span>'):format(v) end
)
artist = '[[曲师列表#'..song.artist..'|'..artist..']]'
end
data:insert(input '音乐家' or artist)
local cc = 'Collaboration %- Collaboration'
local ccl = 'Collaboration#Collaboration'
local ccd = 'Collaboration'
local pack_main = string.gsub(trans.packName[song.set] or packItem['name'], cc, ccl)
local pack_md = string.gsub(pack_main, ccl, ccd)
if mobile_id[id] and ns_id[NSid] then
packItem_ns = mad.packQueryWrap(ns_song[NSid].set, 'ns')
local pack_ns = string.gsub(trans.packName[ns_song[NSid].set] or packItem_ns['name'], cc, ccl)
local pack_nd = string.gsub(pack_ns, ccl, ccd)
if pack_ns == pack_main then
pack = link(pack_main, pack_md)
else
pack = link(pack_main, pack_md) .. onlyMobile .. '<br \>' ..link(pack_ns, pack_nd) .. onlyNS
end
elseif mobile_id[id] then
pack = link(pack_main, pack_md) .. onlyMobile
else
pack = link(pack_main, pack_md) .. onlyNS
end
if ns_id then
packItem_ns = mad.packQueryWrap(song.set, 'ns')
local pack_n = packItem_ns['name']
end
data:insert(input '所属曲包' or pack)
local bpm = tonumber(input 'BPM') or song.bpm_base
data:insert((tonumber(song.bpm) ~= bpm and ('data-sort-value=%s|'):format(bpm) or '') .. song.bpm)
data:insert(durArgs[id] or ' @ ')
data:insert(song.version .. '.' .. (input '收录版本' or verQuery(song.date)))
-- diffs
for i = 1, 4 do
diff = song.difficulties[i]
data:insert(input('等级', i) or (diff and diff.rating .. (diff.ratingPlus and '+' or '')) or '/')
end
end
table.sort(view,
function(a, b)
a, b = a.sort, b.sort
for i = 1, 3 do
local d = a[i] - b[i]
if d ~= 0 then return d < 0 end
end
return false
end)
local res = {}
local template = '|-\n|%s' .. '||[[文件:Songs %s.jpg|75px]]' .. ('||%s'):rep(10)
for idx, value in ipairs(view) do
res[idx] = template:format(unpack(value.data))
end
return table.concat(res, '\n')
end
function p.multi(frame)
for record in mw.text.gsplit(frame.args._ver_, '%s') do
local date, name = record:match '(%d+):(.*)'
table.insert(dates, tonumber(date))
table.insert(versionNames, name)
end
return main(frame:getParent().args, frame.args)
end
return p