跳到内容
折叠侧栏
搜索
创建账号
个人工具
创建账号
登录
导航
首页
最近更改
随机页面
编者用页面
方针
指引
讨论版
格式手册
挂起清单
维护清单
玩法条目
游戏玩法
界面
机制
搭档
潜力值
Link Play
世界模式
故事模式
段位挑战
解歌系统
成就系统
版本更新日志
列表条目
定数表
曲目列表
曲包列表
曲师列表
谱师列表
画师列表
背景列表
友情链接
Rotaeno中文维基
工具
链入页面
相关更改
特殊页面
页面信息
查看“Module:Partnertable”的源代码
模块
讨论
English
阅读
查看源代码
查看历史
更多
阅读
查看源代码
查看历史
←
Module:Partnertable
因为以下原因,您没有权限编辑本页:
您请求的操作仅限属于该用户组的用户执行:
用户
您可以查看和复制此页面的源代码。
local getArgs = require('Module:Arguments').getArgs local link = require('Module:Link')._link local getData = require("Module:data") local p = {} function labelText(text,class) local span = mw.html.create( 'span' ) span:addClass( 'label-text' ) span:wikitext(text) return tostring(span) end function update(version,device,awakenyes,version2) if device == 'ns' then return '<div class="date-box"><div>'..labelText('NS版')..'</div><div>'..version..'</div><div></div></div>' else if awakenyes then return '<div class="date-box"><div>'..labelText('移动版')..'</div><div>搭档:'..version..'<br />觉醒形态:'..version2..'</div><div></div></div>' end return '<div class="date-box"><div>'..labelText('移动版')..'</div><div>'..version..'</div><div></div></div>' end end function skill(text,awakenyes,label) if awakenyes then return '<div><span class="label-text">'..label..'形态</span></div>'..text else return text end end function version(time) local ans if string.byte(time,7) == 99 or string.byte(time,7) >= 48 and string.byte(time,7) <= 57 then ans = 7 else ans = 6 end return string.sub(time,1,ans) end function getImage(normal,awaken,JacketArgs,awakenyes,type,size) local container,tab=mw.html.create('div'),mw.html.create('div') local tab1,tab2,part1,part2,jacket container:addClass( 'container' ) tab:attr( 'id','tab-'..type ) tab:addClass( 'img-tab' ) local Jacket=JacketArgs if awaken then tab1,tab2,part1,part2=mw.html.create('div'),mw.html.create('div'),mw.html.create('div'),mw.html.create('div') tab1:wikitext('Normal') tab2:wikitext('Awaken') tab1:addClass('img-tab-part normal') tab2:addClass('img-tab-part awaken') tab:wikitext(tostring(tab1)) tab:wikitext(tostring(tab2)) container:wikitext(tostring(tab)) part1:wikitext('[[文件:'..normal..'|'..size..'px|none]]'..labelText('画师')..Jacket) part2:wikitext('[[文件:'..awaken..'|'..size..'px|none]]'..labelText('画师')..tostring(Jacket)) part1:addClass('active tab-text-'..type) part2:addClass('tab-text-'..type) container:wikitext(tostring(part1)) container:wikitext(tostring(part2)) return tostring(container) end return '<div><div class="floatnone">[[文件:'..normal..'|'..size..'px]]</div><div>'..labelText('画师')..Jacket..'</div></div>' end function p.main(frame) local args = getArgs(frame) return p._main(args) end function p._main(args) local awaken local size local belongs if args['觉醒形态'] == '有' then awaken=true else awaken=false end if args['名称'] == '白姬' or args['名称'] == '凛可' then size=200 else size=300 end if args['所属曲包'] then belongs='所属曲包' else if args['所属单曲'] then belongs='所属单曲' else belongs='所属单曲/曲包' end end local imageA=getImage(args['图片'],args['觉醒图片'],args['画师'],awaken,'a',size) local imageB=getImage(args['图片'],args['觉醒图片'],args['画师'],awaken,'b',size) local infoList = { [1] = { args['名称'], {id = 'title'}}, [2] = { imageA, {id = 'top-image'}}, [3] = { imageB, {id = 'right-image'}}, [4] = { '搭档信息', {class = 'header'}}, [5] = { '类型', {class = 'label'}}, [6] = { args['类型'], {class = 'data'}}, [7] = { belongs, {class = 'label'}}, [8] = { args['所属曲包'] or args['所属单曲'] or '-', {class = 'data'}}, [9] = { '种类', {class = 'label'}}, [10] = { args['种类'] or '-', {class = 'data'}}, [11] = { '觉醒形态', {class = 'label'}}, [12] = { args['觉醒形态'] or '无', {class = 'data'}}, [13] = { '搭档数据', {class = 'header', id='all-play-header'}}, [14] = { '搭档数据 (移动版)', {class = 'header', id='mobile-play-header'}}, [15] = { '等级', {class = 'label'}}, [16] = { 'Lv1', {class = 'level-data'}}, [17] = { 'Lv20', {class = 'level-data'}}, [18] = { 'Lv30', {class = 'awaken-data'}}, [19] = { 'Frag', {class = 'label'}}, [20] = { args['Frag1'], {class = 'level-data'}}, [21] = { args['Frag20'], {class = 'level-data'}}, [22] = { args['Frag30'], {class = 'awaken-data'}}, [23] = { 'Step', {class = 'label'}}, [24] = { args['Step1'], {class = 'level-data'}}, [25] = { args['Step20'], {class = 'level-data'}}, [26] = { args['Step30'], {class = 'awaken-data'}}, [27] = { 'Over', {class = 'label over'}}, [28] = { args['Over1'], {class = 'level-data over'}}, [29] = { args['Over20'], {class = 'level-data over'}}, [30] = { args['Over30'], {class = 'awaken-data over'}}, [31] = { '搭档数据 (Nintendo Switch版)', {class = 'header ns', id='ns-play-header'}}, [32] = { '等级', {class = 'label ns'}}, [33] = { 'Lv1', {class = 'level-data ns'}}, [34] = { 'Lv20', {class = 'level-data ns'}}, [35] = { 'Lv30', {class = 'awaken-data ns'}}, [36] = { 'Frag', {class = 'label ns'}}, [37] = { args['Frag1NS'], {class = 'level-data ns'}}, [38] = { args['Frag20NS'], {class = 'level-data ns'}}, [39] = { args['Frag30NS'], {class = 'awaken-data ns'}}, [40] = { 'Step', {class = 'label ns'}}, [41] = { args['Step1NS'], {class = 'level-data ns'}}, [42] = { args['Step20NS'], {class = 'level-data ns'}}, [43] = { args['Step30NS'], {class = 'awaken-data ns'}}, [44] = { '技能', {class = 'label', id='skill-label'}}, [45] = { skill(args['技能'] or '-',awaken,'普通'), {class = 'data', id = 'skill-normal'}}, [46] = { skill(args['觉醒技能'],awaken,'觉醒'), {class = 'data', id = 'skill-awaken'}}, [47] = { '更新时间', {id='update-data-label' ,class = 'label'}}, [48] = { update(args['更新时间'] or '无','mobile',awaken,args['觉醒更新时间'] or args['更新时间']), {id='mobile-date-normal', class = 'data'}}, [49] = { update(args['更新时间NS'] or '无','ns',awaken,'无'), {id='ns-date-normal', class = 'data'}} } local box = mw.html.create( 'div' ) --样式控制 box:addClass( "partnerbox" ) if awaken then box:addClass( "awaken" ) end if args['名称'] == '白姬' or args['名称'] == '凛可' then box:addClass( "ns-only" ) end if awaken and args['技能'] ~= args['觉醒技能'] and args['觉醒技能'] ~= nil then box:addClass( "skill-different" ) end if args['类型']=='支援型' then box:addClass( "support" ) else if args['类型']=='挑战型' then box:addClass( "challenge" ) else box:addClass( "balance" ) end end if args['更新时间NS'] then box:addClass( "ns-box" ) end --表格生成 local boxList={} for i, o in ipairs(infoList) do boxList[i] = mw.html.create('div') boxList[i] :attr(infoList[i][2]) :cssText(infoList[i][3]) :wikitext(infoList[i][1]) box:wikitext(tostring(boxList[i])) end --分类添加 local category = '' --平台 if args['更新时间NS'] then if args['更新时间'] then category = category..'[[分类:双平台搭档]]' else category = category..'[[分类:NS版搭档]]' end else category = category..'[[分类:移动版搭档]]' end --觉醒 if awaken then category = category..'[[分类:有觉醒形态的搭档]]' else category = category..'[[分类:没有觉醒形态的搭档]]' end --类型 category = category..'[[分类:'..(args['类型'] or '平衡型')..'搭档]]' --种类 local c1,c2=string.sub(args['种类'],1,6),string.sub(args['种类'],-6,-1) if c1 == '限时' then c1='限时活动' end if c1 == '特殊' then c1='获取方式特殊的' end if c2 == '原创' then c2='限时活动' end if c2 == '专辑' then c2='Arcaea原声专辑特典' end category = category..'[[分类:'..c1.. '搭档]]' category = category..'[[分类:'..c2.. '搭档]]' --版本 if args['更新时间'] then category = category..'[[分类:'..string.gsub(version(args['更新时间']),'v','V').. '添加的搭档]]' end if awaken then category = category..'[[分类:'..string.gsub(version(args['觉醒更新时间'] or args['更新时间']),'v','V').. '添加觉醒形态的搭档]]' end if args['更新时间NS'] then category = category..'[[分类:NS '..string.gsub(version(args['更新时间NS']),'v','V')..'添加的搭档]]' end return tostring(box)..category end return p
本页使用的模板:
Module:Partnertable/doc
(
查看源代码
)
返回
Module:Partnertable
。