打开/关闭菜单
打开/关闭外观设置菜单
打开/关闭个人菜单
未登录
登录后可编辑和发表评论。

Module:沙盒

来自Vocawiki
Wecury留言 | 贡献2025年12月25日 (四) 16:57的版本
模块文档  [查看] [编辑] [历史] [刷新]
欢迎来到Vocawiki公共沙盒
  • 您可以在登录后点击右上角的编辑按钮开始测试;
  • 本页面存在内容为正常现象,您可以直接将其删除并进行自己的测试。当然,请不要删除本模板;
  • 本页面随时可能会被清空,请及时将代码保存至其它地方。您亦可在自己的沙盒进行测试。
local p = {}

local REDIRECT_PREFIX = "/Special:Redirect/file/"

local BASE_ICON_STYLE =
    "-webkit-mask-repeat:no-repeat;" ..
    "-webkit-mask-position:center;" ..
    "-webkit-mask-size:contain;"

local function buildIconStyle(icon)
    if not icon or icon == "" then
        return ""
    end

    icon = mw.text.trim(tostring(icon))

    if not icon:match("^[%w%-%_ %.]+%.svg$") then
        return ""
    end

    local filename = icon:gsub(" ", "_")
    local encoded = mw.uri.encode(filename, "PATH")
    local url = REDIRECT_PREFIX .. encoded

    return string.format("-webkit-mask-image:url(%s);", url)
end

local function buildIconAttr(args)
    local style = BASE_ICON_STYLE .. buildIconStyle(args.icon)
    return ' style="' .. style .. '"'
end

function p.main(frame)
    local args = frame:getParent().args
    local type_ = args.type or "info"
    local iconAttr = buildIconAttr(args)

    -- text模式
    local textContent = args.text or args[1]
    if textContent and textContent ~= "" then
        return string.format([[
<div class="notice notice-%s">
  <div class="notice-icon"%s></div>
  <div class="notice-text text-base">
    <div class="notice-text-only text-base">%s</div>
  </div>
</div>
]], type_, iconAttr, textContent)
    end

    -- 列表
    local listItems = {}
    for i = 1, 50 do
        local key = "l" .. i
        if args[key] and args[key] ~= "" then
            table.insert(listItems, "<li>" .. args[key] .. "</li>")
        end
    end

    local listHtml = ""
    if #listItems > 0 then
        listHtml = '<ul class="notice-list text-sm">' .. table.concat(listItems, "\n") .. "</ul>"
    elseif args.list and args.list ~= "" then
        listHtml = '<ul class="notice-list text-sm">' .. args.list .. "</ul>"
    end

    return string.format([[
<div class="notice notice-%s">
  <div class="notice-icon"%s></div>
  <div class="notice-text text-base">
    <div class="notice-title text-base">%s</div>
    %s
    <div class="notice-detail text-sm">%s</div>
  </div>
</div>
]], type_, iconAttr, args.title or "", listHtml, args.detail or "")
end

return p