此处公告通常对读者进行申明或对该WIKI某些规则进行公告,请在确认后修改本通告
本WIKI编辑权限开放,欢迎收藏起来防止迷路,也希望有爱的小伙伴和我们一起编辑哟~
编辑帮助:目录 • BWIKI反馈留言板
此处公告通常对读者进行申明或对该WIKI某些规则进行公告,请在确认后修改本通告。本WIKI编辑权限开放,欢迎收藏起来防止迷路,也希望有爱的小伙伴和我们一起编辑哟~
模块:DragonSoul
此模块的文档可以在模块:DragonSoul/doc创建
local p = {}
local Highlight = require('Module:Highlight') -- usage: highlightContent
local Data = mw.text.jsonDecode(mw.title.new('Data:龙文.json'):getContent() or '{}')
local starData = mw.text.jsonDecode(mw.title.new('Data:龙文/星级效果.json'):getContent() or '{}')
function p.main(frame)
-- 获取传入的第一个参数(龙文的名字)
local param = frame.args[1]
local output = {}
-- 使用传入的参数作为龙文的名字
local dragonsoul = Data[param] -- 使用传入的参数
local name = param -- 龙文的名字
local type = dragonsoul.type
local skill = dragonsoul.skill
local effect = dragonsoul.effect
local rare = dragonsoul.rare
local en_type = (type == "攻击型" and "attack") or (type == "防御型" and "defense") or (type == "辅助型" and "support")
local deco = (type == "攻击型" and "1") or (type == "防御型" and "2") or (type == "辅助型" and "3")
local orderedOptions = {
"康斯坦丁的追忆",
"奥丁之怒吼",
"利维坦之歌",
"耶梦加得的低语",
"白帝御诏",
"大蛇信语",
"天照命的神言",
"月读命的颂章"
}
table.insert(output,'<div style="display:flex;position:fixed;z-index:4;top:150px;left:12px">')
for _, suffix in ipairs({1, 2, 3, 4, "光", "暗"}) do
local enSuffix = (suffix == "光" and "Light") or (suffix == "暗" and "Dark") or tostring(suffix)
-- 添加龙纹选择框
table.insert(output, string.format('<div class="dragonsoul-select-container" id="select-dragonsoul-container-%s" style="">', enSuffix))
table.insert(output, string.format('<div class="dragonsoul-select-title">部位-%s</div>', suffix))
-- 遍历按照顺序排列的选项
for _, option in ipairs(orderedOptions) do
local optionData = Data[option] -- 获取对应的选项数据
if optionData then
table.insert(output, '<div class="dragonsoul-select-item">')
table.insert(output, string.format('<div class="select-dragonsoul-img">[[file:龙文_%s.png|link=]]%s</div>', option, option))
-- 获取该选项对应的 effect 数据
local optionEffect = optionData.effect[suffix]
local outputOptionEffect = highlightContent(optionEffect)
-- 输出效果内容
table.insert(output, string.format('<div style="font-size:x-small;color:#ffffffde">%s</div>', outputOptionEffect))
table.insert(output, '</div>') -- 关闭 select-item
end
end
table.insert(output, '</div>')
end
table.insert(output, '</div>')
-- 填充标题部分
table.insert(output, '<div class="dragonsoul-title">')
table.insert(output, '<div style="font-size: large;margin-left:8px">龙文 <sub style="font-family: Merriweather;color: #a7a7a7;font-size: small;font-style: italic;"> / DragonSoul</sub></div>')
table.insert(output, string.format('<div class="dragonsoul-title-background-%s" style="display:flex;justify-content: space-between;"><div style="position:relative;z-index:1;">%s [[file:icon_%s1.png|24px]] <span style="font-size:small">推荐:%s</span></div>', en_type, name, en_type, type))
table.insert(output, '<div style="float:right;display:flex;margin-right:72px;">')
for _, switchName in ipairs(orderedOptions) do
table.insert(output,string.format('<div>[[file:龙文_%s.png|30px|link=%s]]</div>',switchName,switchName))
end
table.insert(output, '</div>')
table.insert(output, string.format('<div class="dragonsoul-title-deco">[[file:icon_dragonsoul_decoration%d.png|200px|link=]]</div>', deco))
table.insert(output, '</div></div>')
table.insert(output,'<br/><div style="font-style:italic;font-size:small;color:#a7a7a7">点击龙文图标或信息框可以查询该部位其他龙文的部件技能。如有错漏或补充请在评论告知(*/ω\*)</div>')
table.insert(output, '<div class="dragonsoul-circle-bg">')
table.insert(output, string.format('<div class="dragonsoul-rare">[[file:icon_%s.png|72px]]</div>', rare))
-- 填充套装属性
table.insert(output, '<div class="dragonsoul-setEffect-container">')
table.insert(output, '<div class="dragonsoul-setEffect-title">套装属性</div>')
table.insert(output, '<div class="dragonsoul-setEffect-text">')
-- 预定义技能效果描述
local skillDescriptions = {
"2件套",
"4件套",
"集齐24星时"
}
-- 遍历 skill 数组并显示每个技能效果
for i, skillDesc in ipairs(skill) do
local description = skillDescriptions[i] or "未知技能效果"
table.insert(output, string.format('<span class="dragonsoul-setEffect-badge">%s</span>%s<br/>', description, highlightContent(skillDesc)))
end
table.insert(output, '</div></div>')
-- 填充圆圈容器
table.insert(output, '<div class="dragonsoul-circle-container">')
-- 将隐藏字段替换为 div,并使用 data-* 属性来存储数据
--table.insert(output, '<div id="selected-dragonsoul-id" data-selected-id="" style="display:none;"></div>')
for _, suffix in ipairs({1, 2, 3, 4, "光", "暗"}) do
-- 获取数据
local getStarData = starData[type][suffix]
if getStarData then
-- 处理光暗部分,英文后缀
local enSuffix = (suffix == "光" and "Light") or (suffix == "暗" and "Dark") or tostring(suffix)
local imageSuffix = (suffix == "光" and "Light") or (suffix == "暗" and "Dark") or tostring(suffix)
local imageName = (imageSuffix == "") and name or (name.."_" .. suffix)
local bgClass = (suffix == "光" or suffix == "暗") and "bg" .. imageSuffix or string.format("bg%s", enSuffix)
-- 设置图片名称和后缀
local i1to4 = (suffix == "光" and "Light") or (suffix == "暗" and "Dark") or ''
local image1to4 = (suffix == "光" and name.."_".."光") or (suffix == "暗" and name.."_".."暗") or name
-- 添加背景和图片
table.insert(output, string.format('<div class="dragonsoul-circle-item dragonsoul-bg dragonsoul-%s">[[file:龙文_背景_ssr.png|72px|link=]]</div>', bgClass))
table.insert(output, string.format('<div class="dragonsoul-circle-item dragonsoul-%s" id="select-button-%s">[[file:龙文_%s.png|56px|link=]]', enSuffix, enSuffix, image1to4))
-- 文本框
table.insert(output, '<div class="dragonsoul-text-box dragonsoul-text-box-' .. enSuffix .. '">')
table.insert(output, string.format('<div class="dragonsoul-text-box-icon dragonsoul-text-box-name">%s-%s</div>', name, suffix))
-- 部件技能从 effect 字段获取
local partSkill = effect[(suffix)]
table.insert(output, string.format('<div style="color:#c3b0b0">部件技能(Lv.100,8阶时)</div>%s', highlightContent(partSkill) or "无部件技能"))
table.insert(output, '<div style="color:#c3b0b0">星级属性</div>')
table.insert(output, '<div class="dragonsoul-text-box-starEffect-container">')
-- 填充星级属性
for i = 1, 6, 2 do -- 每次增加 2,意味着每两项属性放在一行
-- 获取当前的两项属性
local attribute1 = getStarData[i].attribute
local value1 = getStarData[i].value
local attribute2 = getStarData[i+1] and getStarData[i+1].attribute or ""
local value2 = getStarData[i+1] and getStarData[i+1].value or ""
-- 开始一行
table.insert(output, string.format('<div class="dragonsoul-text-box-starEffect-eachRow">'))
-- 第一项属性
table.insert(output, string.format('<div class="dragonsoul-text-box-starEffect-item"><div class="dragonsoul-star">[[file:icon_star.png|8px]]%s</div><div>%s</div></div>', attribute1, value1))
-- 第二项属性 (如果存在)
if attribute2 ~= "" then
table.insert(output, string.format('<div class="dragonsoul-text-box-starEffect-item"><div class="dragonsoul-star">[[file:icon_star.png|8px]]%s</div><div>%s</div></div>', attribute2, value2))
end
-- 结束当前行
table.insert(output, '</div>') -- 单行结束
end
-- 结束星级容器
table.insert(output, '</div>') -- 星级总flex
table.insert(output, '</div>') -- 龙文信息结束
table.insert(output, '</div>')
else
-- 如果没有对应数据,可以跳过,或者显示错误信息
table.insert(output, string.format('<div class="dragonsoul-circle-item dragonsoul-%s">没有数据</div>', suffix))
end
end
-- 结束圆圈容器,在循环外关闭
table.insert(output, '</div>')
table.insert(output, '</div>') -- circlebg
-- 返回输出
return table.concat(output)
end
return p