跳到内容
折叠侧栏
搜索
创建账号
个人工具
创建账号
登录
导航
首页
最近更改
随机页面
编者用页面
方针
指引
讨论版
格式手册
挂起清单
维护清单
玩法条目
游戏玩法
界面
机制
搭档
潜力值
Link Play
世界模式
故事模式
段位挑战
解歌系统
成就系统
版本更新日志
列表条目
定数表
曲目列表
曲包列表
曲师列表
谱师列表
画师列表
背景列表
友情链接
Rotaeno中文维基
工具
链入页面
相关更改
特殊页面
页面信息
查看“Module:ArtistSong”的源代码
模块
讨论
English
阅读
查看源代码
查看历史
更多
阅读
查看源代码
查看历史
←
Module:ArtistSong
因为以下原因,您没有权限编辑本页:
您请求的操作仅限属于该用户组的用户执行:
用户
您可以查看和复制此页面的源代码。
local CALv2 = mw.loadJsonData 'Template:ComplexArtistsList.json' local multiId = mw.loadJsonData 'Template:Transition.json'.multiId local trans = mw.loadJsonData 'Template:Transition.json' local SL = mw.loadJsonData 'Template:Song Length.json' local mad = require 'Module:AnotherData' local data = require "Module:Arcaea Data" local CL = require 'Module:ConvertLink' local queryMO = data.allSongInformation("id", "mobile") local queryNS = data.allSongInformation("id", "ns") local function readList() local pickList = {} local pickListBYD = {} for _, song in ipairs(mad.listOf('songs', 'mobile')) do if not song.deleted then local artist = song.artist pickList[song.id] = song.artist if song.difficulties[4] and (song.difficulties[4].artist or song.difficulties[4].title_localized) then local bydArtist = song['difficulties'][4]['artist'] or song.artist pickListBYD[song['id']] = bydArtist end end end for _, song in ipairs(mad.listOf('songs', 'ns')) do if not pickList[song.id] and not multiId[song.id] then pickList[song.id] = song.artist if song.difficulties[4] and song.difficulties[4].artist or song.difficulties[4].title_localized then local bydArtist = song['difficulties'][4]['artist'] or song.artist pickListBYD[song['id']] = bydArtist end end end return pickList, pickListBYD end local function convertPick(pickList, pickListBYD) convertList = {} for _id,_ in pairs(pickList) do local artist = pickList[_id] if not convertList[artist] then convertList[artist] = {} end if not convertList[artist].normal then convertList[artist]['normal'] = {} end table.insert(convertList[artist]['normal'], _id) end for _id in pairs(pickListBYD) do local artist = pickListBYD[_id] if not convertList[artist] then convertList[artist] = {} end if not convertList[artist].beyond then convertList[artist]['beyond'] = {} end table.insert(convertList[artist]['beyond'], _id) end return convertList end local zhName = {} local function genList(convertList) local function cate(singleList, cArtist, artist) local artist = artist or cArtist if not singleList[artist] then singleList[artist] = {} end if convertList[cArtist].beyond then if not singleList[artist].beyond then singleList[artist]['beyond'] = {} end for _,i in pairs(convertList[cArtist]['beyond']) do table.insert(singleList[artist]['beyond'],i) end end if convertList[cArtist].normal then if not singleList[artist].normal then singleList[artist]['normal'] = {} end for _,i in pairs(convertList[cArtist]['normal']) do table.insert(singleList[artist]['normal'],i) end end return singleList end local singleList = {} for cArtist in pairs(convertList) do local artistlist={} if CALv2[cArtist] then if CALv2[cArtist].__FullData__ then for _,text in pairs(CALv2[cArtist].__FullData__) do if text.link then local artist = text.link if not artistlist[artist] then singleList = cate(singleList, cArtist, artist) artistlist[artist]=1 if text.zh then zhName[artist] = true end end end end else for link in pairs(CALv2[cArtist]) do local artist = link if not artistlist[artist] then singleList = cate(singleList, cArtist, artist) artistlist[artist]=1 end end end else singleList = cate(singleList, cArtist) end end return singleList end local function isLetter(char) return char:match("%a") ~= nil end -- 排序 local function customSort(a, b) local a1 = a:sub(1, 1) local b1 = b:sub(1, 1) local la1 = isLetter(a:sub(1, 1)) local lb1 = isLetter(b:sub(1, 1)) if la1 and not lb1 then return true elseif lb1 and not la1 then return false elseif string.lower(a1) == string.lower(b1) then local la2 = isLetter(a:sub(2, 2)) local lb2 = isLetter(b:sub(2, 2)) if la2 and not lb2 then return true elseif lb2 and not la2 then return false else return string.lower(a) < string.lower(b) end else return string.lower(a) < string.lower(b) end return string.lower(a) < string.lower(b) end local function songTitle(id,byd) local display local title = queryMO(id, 'title') or queryNS(id, 'title') if byd then display = queryMO(id, 'bydSongName') or queryNS(id, 'bydSongName') or 'cant find BYD' else display = title end local res = trans.songNameToDisplayName[title] if res then return res..'|'..display end res = trans.sameName[title] if res then return res[id]..'|'..display end if title then return title..'|'..display else return id end end local function songBPM(id, byd) local bpm if byd then bpm = queryMO(id, 'bydBPM') or queryNS(id, 'bydBPM') if bpm then return bpm end end bpm = queryMO(id, 'bpm') or queryNS(id, 'bpm') if bpm then return bpm else return nil end end local lang = mw.language.getContentLanguage() local function songDate(id, byd) local date, ver if byd then date = queryMO(id, 'bydDate') or queryNS(id, 'bydDate') if date then return date end end date = queryMO(id, 'date') or queryNS(id, 'date') if date then return date else return 0 end end local function songVer(id, byd) local date, ver if byd then ver = queryMO(id, 'bydVersion') or queryNS(id, 'bydVersion') if ver then return ver end end ver = queryMO(id, 'version') or queryNS(id, 'version') if ver then return ver else return id end end local function songPack(id) local packid,plat,isNS -- if queryNS(id, 'set') then -- packid = queryNS(id, 'set') -- plat = 'ns' -- isNS = 1 if queryMO(id, 'set') then packid = queryMO(id, 'set') else return nil end local packName = trans.packName[packid] or mad.packQueryWrap(packid, plat).name local packLink = CL.packLink(packName,1,isNS) return packLink end local function songLength(id,byd) if byd then return SL.beyond[id] else return SL.normal[id] end end function p.main(frame) local parentArgs = frame:getParent().args local Args = frame.args local rl, rlb = readList() local cl = convertPick(rl, rlb) local gl = genList(cl) rl,rlb,cl = nil local appendList = Args['appendList'] if appendList then local list = mw.text.split(appendList,'/') for _,id in pairs(list) do local artists = Args[id .. '.'..'artist'] local artistList = mw.text.split(artists,'/') for _, artist in pairs(artistList) do if gl[artist] and gl[artist].normal then table.insert(gl[artist].normal, id) end end end end local wikiText = "" local a2z = {} local gl2 = {} for name in pairs(gl) do local enName if mw.ustring.match(name,'[一-龠ぁ-ゔァ-ヴー々〆〤ヶ]+') then -- enName = parentArgs[name .. '.enName'] or name--nil local enHide = parentArgs[name .. '.enHideName'] local notJaName = parentArgs[name .. '.notJaName'] or zhName[name] enName = enHide or parentArgs[name .. '.enName'] or name--nil gl2[enName] = gl[name] gl2[enName].localName = name if enHide then gl2[enName].enHide = 1 end if notJaName then gl2[enName].notJa = 1 end else enName = name gl2[enName] = gl[name] end gl2[enName].otherName = parentArgs[name .. '.otherName'] or nil gl2[enName].description = parentArgs[name .. '.description'] or nil table.insert(a2z,enName) end table.sort(a2z, customSort) -- 生成页首 local menuName={nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil} for _, name in ipairs(a2z) do local catId=27 local first=string.lower(name:sub(1, 1)) if isLetter(first) then catId=string.byte(first)-string.byte("a")+1 end if menuName[catId]==nil then menuName[catId]=name end end if menuName[27]==nil then menuName[27]="" end for i=26,1,-1 do if menuName[i]==nil then menuName[i]=menuName[i+1] end end local menu={} for _, name in ipairs(menuName) do if gl2[name] then table.insert(menu,gl2[name].localName or name) else table.insert(menu,name) end end wikiText = wikiText .. frame:expandTemplate{ title = "目录", args = menu } .. "\n\n" local function tableAppend(line,newStr) return line..'|'..newStr..'\n' end local function songArg(artist,id,byd,arg) arg = '.'..arg artist = artist .. '.' local function fun(a) return a and artist..a..arg end if byd then return parentArgs[fun(queryMO(id, 'bydSongName'))] or parentArgs[fun(id..'.byd')] else return parentArgs[fun(queryMO(id, 'title'))] or parentArgs[fun(id)] end end local function aslAppend(artist, songid, date, byd) local theList={} local function Input(arg) return songid.. ( byd and '.byd' or '') ..(arg and '.'..arg or '') end local function aInput(arg) return artist ..'.' .. Input(arg) end local function none(arg) return '|<span title="'.. aInput(arg) .. '">' .. '--'..'</span>' end theList.title = ("[[" .. (Args[Input('title')] or songTitle(songid,byd)) .. "]]") or none() theList.length = Args[Input('length')] or songLength(songid,byd) or none() theList.bpm = Args[Input('bpm')] or songBPM(songid,byd) or none() theList.pack = Args[Input('pack')] or songPack(songid) or none() local releaseVer, releaseDate = CL.fullVersionNum(songVer(songid,byd), date) local ver = Args[Input('ver')] or releaseVer or none() theList.date = Args[Input('date')] or releaseDate local AprilFoolVer = Args[Input('AprilFoolVer')] theList.AprilFoolDate = Args[Input('AprilFoolDate')] local afVer if AprilFoolVer and theList.AprilFoolDate then afVer = ("'''愚人节'''<br>"..'v'..AprilFoolVer .. '<br />('.. theList.AprilFoolDate .. ")<br>'''常驻'''<br>") or '' end theList.displayVer = (afVer or '')..'v'..ver .. '<br />('.. theList.date .. ')' or none() theList.text = songArg(artist,songid,byd,'text') or none('text') return theList end for _, name in ipairs(a2z) do local item = gl2[name] local displayName, usingName,other if item.otherName then other = (' ('..item.otherName..')') or nil end if item.localName then usingName = item.localName enDisplay = item.enHide and '' or ' (' .. name ..')' if item.notJa then displayName = usingName .. (other or '') .. enDisplay else displayName = '-{<span lang="ja">' .. usingName .. '</span>}-' .. (other or '') .. enDisplay end else usingName = name displayName = name .. (other or '') end -- wikiText = wikiText .. '*' .. usingName .. '\n' wikiText = wikiText .. '<span id="' .. usingName .. '" />\n' wikiText = wikiText .. '== <span title="'.. usingName .. '">' .. displayName..'</span> ==\n' -- wikiText = wikiText .. 'Span id: ' .. usingName .."\n" wikiText = wikiText .. (item.description or '') .. '\n' wikiText = wikiText .. '{| class="wikitable" border="1" cellspacing="1" cellpadding="5" style="text-align:center;width: 100%"\n' wikiText = wikiText .. '! style="width: 30.5%;"|曲目名称\n' wikiText = wikiText .. '! style="width: 6%;"|时长\n' wikiText = wikiText .. '! style="width: 10%;"|BPM\n' wikiText = wikiText .. '! style="width: 18.5%;"|曲包\n' wikiText = wikiText .. '! style="width: 15%;"|发布版本\n' wikiText = wikiText .. '! style="width: 20%;"|备注\n' local artistSongList = {} local listSort = {} if item.normal then for _,songid in ipairs(item.normal) do local date = songDate(songid) local theList=aslAppend(usingName, songid, date) local aslId = (theList.AprilFoolDate or theList.date)..songid artistSongList[aslId] = theList table.insert(listSort, aslId) end end if item.beyond then for _,songid in ipairs(item.beyond) do local date = songDate(songid, 1) local theList = aslAppend(usingName, songid, date, 1) local aslId = (theList.AprilFoolDate or theList.date)..songid..'byd' artistSongList[aslId] = theList table.insert(listSort, aslId) end end table.sort(listSort) for _,id in ipairs(listSort) do wikiText = tableAppend(wikiText, '-') local theList = artistSongList[id] wikiText = tableAppend(wikiText, theList.title) wikiText = tableAppend(wikiText, theList.length) wikiText = tableAppend(wikiText, theList.bpm) wikiText = tableAppend(wikiText, theList.pack) wikiText = tableAppend(wikiText, theList.displayVer) wikiText = tableAppend(wikiText, theList.text) end wikiText = wikiText .. "|}\n" end return wikiText end return p
本页使用的模板:
Module:ArtistSong/doc
(
查看源代码
)
返回
Module:ArtistSong
。