Module:ChartConstant:修订间差异

来自Arcaea中文维基
无编辑摘要
(修[anti]bug)
 
(未显示4个用户的17个中间版本)
第1行: 第1行:
local mad = require 'Module:AnotherData'
local p = {}
local p = {}
local chartConstantList = mw.text.jsonDecode(mw.getCurrentFrame():expandTemplate{ title = 'ChartConstant.json' })
-- ns待补充(ns也不需要这个)
local songlist = mw.text.jsonDecode(mw.getCurrentFrame():expandTemplate{ title = 'Songlist.json' })
local trans = mw.text.jsonDecode(mw.getCurrentFrame():expandTemplate{ title = 'Template:Transition.json' })


local function itData(datas, cc)
cc = cc or 13
local step, format = unpack(cc > 11 and {1, '%d'} or {.1, '%.1f'})
cc = cc - step
local id = format:format(cc)
local data = datas[id]
if not data then return nil end
return cc, id, data
end
function p.main()
local datas = {}
local songCcs = mw.text.jsonDecode(mw.title.new('ChartConstant.json', 'Template'):getContent())
for _, song in ipairs(mad.listOf 'songs') do
local id, titleBase, dateBase = song.id, mad.title(song), song.date
local songCc = songCcs[id] or {}
local link = mad.linkName(song) or titleBase
for _, chart in ipairs {}, song.difficulties, 1 do
local rc = chart.ratingClass + 1
local chartCc = songCc[rc]
-- fk lua donot support continue. use single-loop & break for subst
repeat
if not chartCc or chartCc.old ~= false then break end
local nCc = chartCc.constant
if nCc < 8 then break end
local title, date = mad.title(chart) or titleBase, chart.date or dateBase


local rowId, sCc
if nCc >= 11 then
rowId = ('%d'):format(nCc)
sCc = ('%.1f'):format(nCc)
else
rowId = ('%.1f'):format(nCc)
end
local rowData = datas[rowId]
if not rowData then
rowData = {}
datas[rowId] = rowData
end
table.insert(rowData, {
data = {title, id, ({'PST', 'PRS', 'FTR', 'BYD', 'ETR'})[rc], link = link, CC = sCc},
sort = {nCc, rc, date}
})
until (true)
end
end


local function cv()
local frame = mw.getCurrentFrame()
local list = {}
local text = mw.html.create 'div':addClass 'notaninfobox dstable'
for i,k in pairs(songlist['songs'])
for _, rowId, rowData in itData, datas do
do
text = text
list[k['id']] = {
:tag 'div':addClass 'ds':wikitext(rowId):done()
k['title_localized']['en']
:tag 'div':addClass 'number'
k["date"],
:wikitext(frame:expandTemplate {title = ' 组排列', args = {height = 'auto'}})
nil,
table.sort(rowData, function(a, b)
nil
a, b = a.sort, b.sort
}
if a[1] ~= b[1] then return a[1] > b[1] end
if k["difficulties"][4] then
if a[2] ~= b[2] then return a[2] > b[2] end
if k["difficulties"][4]["title_localized"] then
return a[3] < b[3]
list[k['id']][3] = k["difficulties"][4]["title_localized"]["en"]
end)
end
for _, rowItem in ipairs(rowData) do
if k["difficulties"][4]["date"] then
text:wikitext(frame:expandTemplate {title = ' 组排单元', args = rowItem.data})
list[k['id']][4] = k["difficulties"][4]["date"]
end
end
end
text = text:wikitext(frame:expandTemplate {title = '组排列-end'}):done()
end
end
return list
 
return tostring(text)
end
end


 
function p.detail()
local specialSongNameConverter = {
local datas = {}
["#1f1e33"] = "#1f1e33",
local songCcs = mw.text.jsonDecode(mw.title.new('ChartConstant.json', 'Template'):getContent())
   ["AI[UE]OON"] = "AI[UE]OON",
for _, song in ipairs(mad.listOf 'songs') do
   ["Last | Eternity"] = "Last",
local id = song.id
   ["Last | Moment"] = "Last"
local songCc = songCcs[id] or {}
}
--
local n = {
local data = {mad.linkTitle(song)}
   ["Last | Eternity"] = "Last \| Eternity",
local sort = {0, song.date}
   ["Last | Moment"] = "Last \| Moment"
table.insert(datas, {data = data, sort = sort})
}
for _, chart in ipairs(song.difficulties) do
 
local rc = chart.ratingClass + 1
function p.main()
local chartCc = songCc[rc]
local list = {}
repeat
local name, link
if not chartCc then break end
local cvList = cv()
local nCc = chartCc.constant
   for i, k in pairs(chartConstantList) do
if not chart.date then sort[1] = nCc end
   if k[2] or k[3] or k[4] then
local sCc = ('%.1f'):format(nCc)
   name = cvList[i][1]
data[rc + 1] = chartCc.old ~= false and tostring(mw.html.create 'span':addClass 'old-constant':wikitext(sCc)) or sCc
until (true)
end
end
     if trans["songNameToDisplayName"][name] then
for i = 2, 6 do
       link = trans["songNameToDisplayName"][name]
data[i] = data[i] or ' '
else
link = name
     end
if n[name] then
name = n[name]
end
end
   if k[2] and tonumber(k[2]['constant'])>=8 and not(k[2]['old']) then
   table.insert(list, { i, name, k[2]['constant'], "PRS", link, cvList[i][2] })
   end
   if k[3] and tonumber(k[3]['constant'])>=8 and not(k[3]['old']) then
   table.insert(list, { i, name, k[3]['constant'], "FTR", link, cvList[i][2] })
   end
   if k[4] and tonumber(k[4]['constant'])>=8 and not(k[4]['old']) then
   if cvList[i][3] then
name = cvList[i][3]
end
if cvList[i][4] then
table.insert(list, { i, name, k[4]['constant'], "BYD", link, cvList[i][4] })
else
   table.insert(list, { i, name, k[4]['constant'], "BYD", link, cvList[i][2] })
end
   end
   end
  
-- make lists
   local result = {}
   local mid_result = {}
   result[11], result[12] = {}, {}
   mid_result[11], mid_result[12] = {}, {}
   for s, k in pairs(list) do
     if not(mid_result[k[3]]) then mid_result[k[3]]={} end
     if k[3]>=11 then
       if k[3]>=12 then
         table.insert(mid_result[12], k)
       else
         table.insert(mid_result[11], k)
       end
     else table.insert(mid_result[k[3]], k) end
   end
   -- sort songs
   local diffConverter = { PRS=2, FTR=3, BYD=4 }
   for s, k in pairs(mid_result) do
     table.sort(k, function (a, b)
       if not(a[3]==b[3]) then
         return a[3]>b[3]
       end
return a[6]<b[6]
--[=[
       if not(diffConverter[a[4]]==diffConverter[b[4]]) then
         return diffConverter[a[4]]>diffConverter[b[4]]
       else return string.upper(a[2])<string.upper(b[2]) end
]=]
     end)
   end
-- use template
-- 组排单元 第一个参数是曲名,第二个是id,第三个是难度,link字面意思
   for s, k in pairs(mid_result) do
   if s<11 then
   if not(result[s]) then result[s]={} end
       for n, m in pairs(k) do
         table.insert(result[s],mw.getCurrentFrame():expandTemplate { title = '组排单元', args = { m[2], m[1], m[4], link=m[5] } } )
       end
   else
   if s<12 then
   for n, m in pairs(k) do
           table.insert(result[11],mw.getCurrentFrame():expandTemplate { title = '组排单元', args = { m[2], m[1], m[4], CC = string.format("%.1f", m[3]), link=m[5] } } )
         end
   else
   for n, m in pairs(k) do
           table.insert(result[12],mw.getCurrentFrame():expandTemplate { title = '组排单元', args = { m[2], m[1], m[4], CC = string.format("%.1f", m[3]), link=m[5] } } )
         end
   end
   end
   end
-- sort constants
local sortTable = {}
for i,k in pairs(result) do
table.insert(sortTable, {i, k})
end
end
table.sort(sortTable, function(a,b) return a[1] > b[1] end)


-- add head and end
table.sort(datas, function(a, b)
local finText = "<div class='notaninfobox dstable'>\n"
a, b = a.sort, b.sort
if a[1] == b[1] then return a[2] < b[2] end
return a[1] > b[1]
end)


for i,k in ipairs(sortTable)
local texts = {}
do
local template = '|-\n|[[%s]]' .. ('||%s'):rep(5)
if k[1] == 11 or k[1] == 12
for _, value in ipairs(datas) do
then
table.insert(texts, template:format(unpack(value.data)))
finText = finText .. "<div class='ds'>"..k[1].."</div>\n"
finText = finText .. "<div class='number'>"..mw.getCurrentFrame():expandTemplate { title = '组排列', args = { ['高度']="154px"  }  }
..table.concat(k[2])..mw.getCurrentFrame():expandTemplate { title = '组排列-end' }.."</div>\n"
else
finText = finText .. "<div class='ds'>"..string.format("%.1f", k[1]).."</div>\n"
finText = finText .. "<div class='number'>"..mw.getCurrentFrame():expandTemplate { title = '组排列' }
..table.concat(k[2])..mw.getCurrentFrame():expandTemplate { title = '组排列-end' }.."</div>\n"
end
end
end
finText = finText .. "</div>"


   return finText
return table.concat(texts, '\n')
end
end


return p
return p

2024年3月15日 (五) 00:57的最新版本

可在Module:ChartConstant/doc创建此模块的帮助文档

local mad = require 'Module:AnotherData'
local p = {}
-- ns待补充(ns也不需要这个)

local function itData(datas, cc)
	cc = cc or 13
	local step, format = unpack(cc > 11 and {1, '%d'} or {.1, '%.1f'})
	cc = cc - step
	local id = format:format(cc)
	local data = datas[id]
	if not data then return nil end
	return cc, id, data
end
function p.main()
	local datas = {}
	local songCcs = mw.text.jsonDecode(mw.title.new('ChartConstant.json', 'Template'):getContent())
	for _, song in ipairs(mad.listOf 'songs') do
		local id, titleBase, dateBase = song.id, mad.title(song), song.date
		local songCc = songCcs[id] or {}
		local link = mad.linkName(song) or titleBase
		for _, chart in ipairs {}, song.difficulties, 1 do
			local rc = chart.ratingClass + 1
			local chartCc = songCc[rc]
			-- fk lua donot support continue. use single-loop & break for subst
			repeat
				if not chartCc or chartCc.old ~= false then break end
				local nCc = chartCc.constant
				if nCc < 8 then break end
				local title, date = mad.title(chart) or titleBase, chart.date or dateBase

				local rowId, sCc
				if nCc >= 11 then
					rowId = ('%d'):format(nCc)
					sCc = ('%.1f'):format(nCc)
				else
					rowId = ('%.1f'):format(nCc)
				end
				local rowData = datas[rowId]
				if not rowData then
					rowData = {}
					datas[rowId] = rowData
				end
				table.insert(rowData, {
					data = {title, id, ({'PST', 'PRS', 'FTR', 'BYD', 'ETR'})[rc], link = link, CC = sCc},
					sort = {nCc, rc, date}
				})
			until (true)
		end
	end

	local frame = mw.getCurrentFrame()
	local text = mw.html.create 'div':addClass 'notaninfobox dstable'
	for _, rowId, rowData in itData, datas do
		text = text
			:tag 'div':addClass 'ds':wikitext(rowId):done()
			:tag 'div':addClass 'number'
			:wikitext(frame:expandTemplate {title = '组排列', args = {height = 'auto'}})
		table.sort(rowData, function(a, b)
			a, b = a.sort, b.sort
			if a[1] ~= b[1] then return a[1] > b[1] end
			if a[2] ~= b[2] then return a[2] > b[2] end
			return a[3] < b[3]
		end)
		for _, rowItem in ipairs(rowData) do
			text:wikitext(frame:expandTemplate {title = '组排单元', args = rowItem.data})
		end
		text = text:wikitext(frame:expandTemplate {title = '组排列-end'}):done()
	end

	return tostring(text)
end

function p.detail()
	local datas = {}
	local songCcs = mw.text.jsonDecode(mw.title.new('ChartConstant.json', 'Template'):getContent())
	for _, song in ipairs(mad.listOf 'songs') do
		local id = song.id
		local songCc = songCcs[id] or {}
		--
		local data = {mad.linkTitle(song)}
		local sort = {0, song.date}
		table.insert(datas, {data = data, sort = sort})
		for _, chart in ipairs(song.difficulties) do
			local rc = chart.ratingClass + 1
			local chartCc = songCc[rc]
			repeat
				if not chartCc then break end
				local nCc = chartCc.constant
				if not chart.date then sort[1] = nCc end
				local sCc = ('%.1f'):format(nCc)
				data[rc + 1] = chartCc.old ~= false and tostring(mw.html.create 'span':addClass 'old-constant':wikitext(sCc)) or sCc
			until (true)
		end
		for i = 2, 6 do
			data[i] = data[i] or ' '
		end
	end

	table.sort(datas, function(a, b)
		a, b = a.sort, b.sort
		if a[1] == b[1] then return a[2] < b[2] end
		return a[1] > b[1]
	end)

	local texts = {}
	local template = '|-\n|[[%s]]' .. ('||%s'):rep(5)
	for _, value in ipairs(datas) do
		table.insert(texts, template:format(unpack(value.data)))
	end

	return table.concat(texts, '\n')
end

return p