Немає опису редагування
Немає опису редагування
Рядок 1: Рядок 1:
local p = {}
local p = {}


-- Цільова дата для розрахунку днів з моменту приєднання (25 жовтня 2024 року)
----------------------------------------------------------------------
local TARGET_DATE_STR = "25.10.2024"
-- ГОЛОВНИЙ ПОШУК
local TARGET_TIMESTAMP = os.time({year=2024, month=10, day=25, hour=0, min=0, sec=0})
-- Шукає у таблиці рядок, де друга колонка = player_name
-- Повертає значення з column_index того ж самого рядка
----------------------------------------------------------------------


--- Функція для вилучення даних з вказаної сторінки та колонки
local function fetch_from_table(page_title, player_name, column_index)
-- @param page_title Назва сторінки (наприклад, "Гравці")
-- @param player_name Ім'я гравця для пошуку (PAGENAME)
-- @param column_index Індекс колонки для вилучення (1 = №, 2 = Пан/Пані, 3 = Дата/Сума/Рахунок, 4 = Провідник)
-- @return Очищене значення або nil
local function fetch_data_from_table(page_title, player_name, column_index)
     local title = mw.title.new(page_title)
     local title = mw.title.new(page_title)
     local content = title and title:getContent()
     if not title then return nil end


     if not content then
    local content = title:getContent()
        return nil
     if not content then return nil end
     end
 
    -- Беремо всю таблицю {| … |}
     local table_content = mw.ustring.match(content, "{|.-|}")
    if not table_content then return nil end


     -- Вилучаємо вміст таблиці wikitable
     -- Escape для імен з дужками/крапками
    -- Використовуємо нежадібний пошук (.-?) між {| і |}
     local escaped = mw.ustring.gsub(player_name, "([%^%$%(%)%%%.%[%]%*%+%-%?])", "%%%1")
     local table_content = mw.ustring.match(content, "{|%s*class%s*=%s*\"wikitable\".-([|].-.-[|]})")
    if not table_content then
        return nil
    end


     local escaped_player = mw.ustring.gsub(player_name, "([%(%)%.%-%+%[%]])", "%%%1")
     -- Патерн для 2-ї колонки:
     local player_link_pattern = "%[?%[" .. escaped_player .. "%]%]?"
    -- | [[Ім’я]]
     local player_pattern = "%[%[" .. escaped .. "%]%]"


    -- 1. СТІЙКИЙ ПОШУК РЯДКА: Шукаємо гравця у ДРУГІЙ колонці
     local target_row = nil
    -- Шаблон:
    -- 1. `[|]%s*.-` - Перша колонка (| 000)
    -- 2. `[|]%s*` - Роздільник
    -- 3. `(.-)` - Друга колонка (захоплюємо вміст, який включає гравця)
    -- 4. `[|]%s*.-[|]` - Захоплюємо решту колонок (3 і 4)
   
    -- Шукаємо послідовність, що включає | <№> | [[Гравець]] |
     local search_pattern = "([|]%s*.-%s*[|]%s*" .. player_link_pattern .. "%s*[|].-)"
    local full_row_match = mw.ustring.match(table_content, search_pattern)


     if not full_row_match then
     -- Шукаємо рядок, який містить [[Name]] у другій колонці
        -- Додатковий пошук на випадок, якщо потрібен символ початку рядка |-\n
    for line in mw.ustring.gmatch(table_content, "[^\n]+") do
        local row_start_pattern = "[|]%s*.-%s*[%-]%s*([|]%s*.-%s*[|]%s*" .. player_link_pattern .. "%s*[|].-)"
        -- Рядки таблиці починаються з |
        full_row_match = mw.ustring.match(table_content, row_start_pattern)
        if mw.ustring.match(line, "^%s*|") and mw.ustring.find(line, player_pattern) then
        if not full_row_match then
            target_row = line
             return nil
             break
         end
         end
     end
     end
      
 
    local columns = {}
     if not target_row then return nil end
      
 
     -- 2. Надійне розділення на комірки.
     ------------------------------------------------------------------
     -- Розділяємо весь захоплений блок на окремі комірки по |
     -- Зчищаємо "|-" і розбиваємо на | cell
     for cell in mw.ustring.gmatch(full_row_match, "[|](.-)") do
     ------------------------------------------------------------------
        local trimmed_cell = mw.text.trim(cell)
     target_row = mw.ustring.gsub(target_row, "^%s*|%-", "")
        -- Видаляємо службові елементи
 
        if trimmed_cell ~= "" and not mw.ustring.match(trimmed_cell, "^!") then
    local cells = {}
            table.insert(columns, trimmed_cell)
    for cell in mw.ustring.gmatch(target_row, "%s*|%s*([^|]+)") do
        end
        table.insert(cells, mw.text.trim(cell))
     end
     end
   
    -- Колонка 1 = №, Колонка 2 = Пан/Пані, Колонка 3 = Дата/Сума, Колонка 4 = Провідник
    local result = columns[column_index]


     if result then
    local result = cells[column_index]
        -- 3. Очищення результату: видалення зовнішніх [[ ]]
     if not result then return nil end
        result = mw.text.trim(mw.ustring.gsub(result, "%[?%[?(.+)%]%]?", "%1"))
 
        return result
    ------------------------------------------------------------------
     else
    -- Прибираємо [[link|text]] і [[link]]
        return nil
    ------------------------------------------------------------------
    end
    result = mw.ustring.gsub(result, "%[%[([^%]|]+)|([^%]]+)%]%]", "%2")
    result = mw.ustring.gsub(result, "%[%[([^%]]+)%]%]", "%1")
 
     return mw.text.trim(result)
end
end


--- Функції, що викликаються шаблоном MCC Player New ---


function p.date_added(frame)
----------------------------------------------------------------------
    local player = frame.args.player
-- Рахує різницю в днях між датою та 25.10.2024
    -- Колонка 3 для Дата приєднання
----------------------------------------------------------------------
    local date_str = fetch_data_from_table("Гравці", player, 3)


     if not date_str or date_str == "" then
local function date_with_days(dateString)
        return "''Невідомо''"
     if not dateString then return "" end
    end


    -- Парсинг дати у форматі DD.MM.YYYY
     local d, m, y = dateString:match("(%d%d)%.(%d%d)%.(%d%d%d%d)")
     local day, month, year = mw.ustring.match(date_str, "(%d%d)%.(%d%d)%.(%d%d%d%d)")
     if not d then return dateString end
   
     if not day then
        return date_str .. " (Помилка формату)"
    end


     local join_timestamp = os.time({year=tonumber(year), month=tonumber(month), day=tonumber(day), hour=0, min=0, sec=0})
     local start = os.time({day = d, month = m, year = y})
   
    local finish = os.time({day = 25, month = 10, year = 2024})
     local diff_seconds = TARGET_TIMESTAMP - join_timestamp
     local diff = math.floor((finish - start) / 86400)
   
    if diff_seconds < 0 then
        return date_str
    end


    -- Розрахунок днів
     return string.format("%s (%d днів)", dateString, diff)
    local diff_days = math.floor(diff_seconds / 86400)
   
     return string.format("%s (%d д)", date_str, diff_days)
end
end
----------------------------------------------------------------------
-- ПОЛЯ
-- Всі функції беруть PAGENAME та шукають його в 2-й колонці таблиці
----------------------------------------------------------------------


function p.recruiter(frame)
function p.recruiter(frame)
     local player = frame.args.player
     local name = mw.title.getCurrentTitle().text
     -- Колонка 4 для Провідника
     return fetch_from_table("Гравці", name, 4) or "Невідомо"
    local recruiter_name = fetch_data_from_table("Гравці", player, 4)
 
    if not recruiter_name or recruiter_name == "" or recruiter_name == "Не вказано" or recruiter_name == "-" or recruiter_name == "Відсутній" then
        return "Не вказано"
    end
   
    -- Додаємо вікі-посилання, якщо його немає
    if mw.ustring.match(recruiter_name, "%[?%[?") then
        return recruiter_name
    else
        return string.format("[[%s|%s]]", recruiter_name, recruiter_name)
    end
end
end


function p.prize_pool(frame)
function p.date_added(frame)
     local player = frame.args.player
     local name = mw.title.getCurrentTitle().text
    -- Колонка 3 для Суми
     local raw = fetch_from_table("Гравці", name, 3)
     local amount = fetch_data_from_table("Призовий_фонд", player, 3)
     return raw and date_with_days(raw) or "Невідомо"
 
     if not amount or amount == "" then
        return "0 ₴"
    end
 
    -- Очищення від символів валют та пробілів
    amount = mw.ustring.gsub(amount, "[^%d%s]", "")
    amount = mw.text.trim(amount)
   
    return amount .. " "
end
end


function p.foundation(frame)
function p.foundation(frame)
     local player = frame.args.player
     local name = mw.title.getCurrentTitle().text
     -- Колонка 3 для Суми
     return fetch_from_table("Фундація", name, 2) or "0"
    local amount = fetch_data_from_table("Фундація", player, 3)
end


    if not amount or amount == "" then
function p.prize_pool(frame)
        return "0 ₴"
     local name = mw.title.getCurrentTitle().text
    end
     return fetch_from_table("Призовий_фонд", name, 2) or "0"
 
    amount = mw.ustring.gsub(amount, "[^%d%s]", "")
     amount = mw.text.trim(amount)
   
     return amount .. " "
end
end


function p.final(frame)
function p.final(frame)
     local player = frame.args.player
     local name = mw.title.getCurrentTitle().text
     -- Колонка 3 для Кількість/Рахунок
     return fetch_from_table("Фіналіст", name, 2) or "Ні"
    local count = fetch_data_from_table("Фіналіст", player, 3)
 
    if not count or count == "" then
        return "0/9"
    end
 
    -- Вилучення лише числа з рядка
    count = mw.ustring.match(count, "(%d+)")
   
    if not count then
        return "0/9"
    end
   
    return count .. "/9"
end
end


return p
return p

Версія за 00:23, 24 листопада 2025

Документацію для цього модуля можна створити у Модуль:FetchData2/документація

local p = {}

----------------------------------------------------------------------
-- ГОЛОВНИЙ ПОШУК
-- Шукає у таблиці рядок, де друга колонка = player_name
-- Повертає значення з column_index того ж самого рядка
----------------------------------------------------------------------

local function fetch_from_table(page_title, player_name, column_index)
    local title = mw.title.new(page_title)
    if not title then return nil end

    local content = title:getContent()
    if not content then return nil end

    -- Беремо всю таблицю {| … |}
    local table_content = mw.ustring.match(content, "{|.-|}")
    if not table_content then return nil end

    -- Escape для імен з дужками/крапками
    local escaped = mw.ustring.gsub(player_name, "([%^%$%(%)%%%.%[%]%*%+%-%?])", "%%%1")

    -- Патерн для 2-ї колонки:
    -- | [[Ім’я]]
    local player_pattern = "%[%[" .. escaped .. "%]%]"

    local target_row = nil

    -- Шукаємо рядок, який містить [[Name]] у другій колонці
    for line in mw.ustring.gmatch(table_content, "[^\n]+") do
        -- Рядки таблиці починаються з |
        if mw.ustring.match(line, "^%s*|") and mw.ustring.find(line, player_pattern) then
            target_row = line
            break
        end
    end

    if not target_row then return nil end

    ------------------------------------------------------------------
    -- Зчищаємо "|-" і розбиваємо на | cell
    ------------------------------------------------------------------
    target_row = mw.ustring.gsub(target_row, "^%s*|%-", "")

    local cells = {}
    for cell in mw.ustring.gmatch(target_row, "%s*|%s*([^|]+)") do
        table.insert(cells, mw.text.trim(cell))
    end

    local result = cells[column_index]
    if not result then return nil end

    ------------------------------------------------------------------
    -- Прибираємо [[link|text]] і [[link]]
    ------------------------------------------------------------------
    result = mw.ustring.gsub(result, "%[%[([^%]|]+)|([^%]]+)%]%]", "%2")
    result = mw.ustring.gsub(result, "%[%[([^%]]+)%]%]", "%1")

    return mw.text.trim(result)
end


----------------------------------------------------------------------
-- Рахує різницю в днях між датою та 25.10.2024
----------------------------------------------------------------------

local function date_with_days(dateString)
    if not dateString then return "" end

    local d, m, y = dateString:match("(%d%d)%.(%d%d)%.(%d%d%d%d)")
    if not d then return dateString end

    local start = os.time({day = d, month = m, year = y})
    local finish = os.time({day = 25, month = 10, year = 2024})
    local diff = math.floor((finish - start) / 86400)

    return string.format("%s (%d днів)", dateString, diff)
end


----------------------------------------------------------------------
-- ПОЛЯ
-- Всі функції беруть PAGENAME та шукають його в 2-й колонці таблиці
----------------------------------------------------------------------

function p.recruiter(frame)
    local name = mw.title.getCurrentTitle().text
    return fetch_from_table("Гравці", name, 4) or "Невідомо"
end

function p.date_added(frame)
    local name = mw.title.getCurrentTitle().text
    local raw = fetch_from_table("Гравці", name, 3)
    return raw and date_with_days(raw) or "Невідомо"
end

function p.foundation(frame)
    local name = mw.title.getCurrentTitle().text
    return fetch_from_table("Фундація", name, 2) or "0"
end

function p.prize_pool(frame)
    local name = mw.title.getCurrentTitle().text
    return fetch_from_table("Призовий_фонд", name, 2) or "0"
end

function p.final(frame)
    local name = mw.title.getCurrentTitle().text
    return fetch_from_table("Фіналіст", name, 2) or "Ні"
end

return p