跳转到内容

模組:VGNL

维基百科,自由的百科全书

这是本页的一个历史版本,由Lopullinen留言 | 贡献2023年8月4日 (五) 10:51 (ㄍ...)编辑。这可能和当前版本存在着巨大的差异。

require('strict')

local p = {}
local getArgs = require('Module:Arguments').getArgs
local function makeInvokeFunc(funcName)
    return function(frame)
        local args = getArgs(frame)
        return p[funcName](args)
    end
end

p.target = makeInvokeFunc('_target')
function p._target(args)
    --[=[ 根据[[WikiProject:電子遊戲/簡訊/目錄]]的期数链接,获取最新简讯页(或当前草稿简讯页)的页面标题

    若 args[1] = 'draft',则检查出刊日期列data-sort-value属性值为"draft########"'的项目,并取属性值最小的项目
    否则,取出刊日期列data-sort-value属性值为"########"'的项目,并属性值最大的项目

    :param args: 传入本模组的参数组
    :return: 最新一期简讯的页面名字符串,如'維基專題:電子遊戲/簡訊/2023-10'
    ]=]

    local is_draft = args[1] == 'draft'
    local toc_page_name = 'WikiProject:電子遊戲/簡訊/目錄'
    local toc_page_content = mw.title.new(toc_page_name):getContent()
    local ptn = '!%s*scope%s*=%s*"row"%s*|%s*%[%[(.-)|.-%]%]%s*' ..
            '|%s*data%-sort%-value%s*=%s*"' .. (is_draft and 'draft' or '') .. '%d%d%d%d%d%d%d%d"'

    local available_page_names = {}
    for v in mw.ustring.gmatch(toc_page_content, ptn) do
        table.insert(available_page_names, v)
    end

    table.sort(available_page_names, function(a, b)
        if is_draft then
            return a < b
        end
        return a > b
    end)
    mw.logObject(available_page_names)

    return available_page_names[1]
end

p.label = makeInvokeFunc('_label')
function p._label(args)
    --[=[ 从当期简讯页面中抓取期号名

    :param args: 传入本模组的参数组
    :return: 最新一期简讯的期号名,如'2023年第三季'
    ]=]

    local target = p._target(args)
    local text = mw.title.new(target):getContent()
    return text:match('%d%d%d%d年第.-季')
end

p.link = makeInvokeFunc('_link')
function p._link(args)
    --[=[ 获取当期简讯主页的内部链接

    :param args: 传入本模组的参数组
    :return: 最新一期简讯的管道链接,如'[[維基專題:電子遊戲/簡訊/2023-10|2023年第三季]]'
    ]=]
    local target = p._target(args)
    local label = p._label(args)
    return '[[' .. target .. '|' .. label .. ']]'
end

p.content = makeInvokeFunc('_content')
function p._content(args)
    --[=[ 生成当期简讯主页的内容

    :param args: 传入本模组的参数组
    :return: 最新一期简讯的内容
    ]=]

    -- ToDo: 移除页面的分类
    local target = p._target(args)
    return mw.getCurrentFrame():expandTemplate { title = target }
end

p.toc = makeInvokeFunc('_toc')
function p._toc(args)
    local target = p._target(args)
    local text = mw.title.new(target):getContent()

    local items = {}
    local pattern = mw.ustring.gsub(target, 'WikiProject:', '維基專題:')
    pattern = '%[%[' .. mw.ustring.gsub(pattern, '%-', '%-') .. '/.-|.-%]%]'
    local pos = 1

    while true do
        local s, e = mw.ustring.find(text, pattern, pos, false)
        if s == nil then
            break
        end
        table.insert(items, mw.ustring.sub(text, s, e))
        pos = e + 1
    end

    if args.style == 'comma' then
        return table.concat(items, '、')
    end

    do
        local items_ = { }
        for _, item in ipairs(items) do
            table.insert(items_, '* ' .. item)
        end
        return table.concat(items_, '\n')
    end
end
return p