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


-- Цільова дата для розрахунку днів з моменту приєднання (25 жовтня 2024 року)
local TARGET_DATE_STR = "25.10.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})  
local TARGET_TIMESTAMP = os.time({year=2024, month=10, day=25, hour=0, min=0, sec=0})  


--- Функція для вилучення даних з вказаної сторінки та колонки
-- @param page_title Назва сторінки (наприклад, "Гравці")
-- @param player_name Ім'я гравця для пошуку
-- @param column_index Індекс колонки (1 = №, 2 = Пан/Пані, 3 = Дата/Сума/Рахунок, 4 = Провідник)
-- @return Очищене значення або nil
local function fetch_data_from_table(page_title, player_name, column_index)
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)
Рядок 12: Рядок 18:
     end
     end


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


     local escaped_player = mw.ustring.gsub(player_name, "([%(%)%.%-%+%[%]])", "%%%1")
     local escaped_player = mw.ustring.gsub(player_name, "([%(%)%.%-%+%[%]])", "%%%1")
   
     local player_link_pattern = "%[?%[" .. escaped_player .. "%]%]?"
     local player_link_pattern = "%[?%[" .. escaped_player .. "%]%]?"
    -- 2. Знайти повний рядок, що містить гравця.
    -- Ми шукаємо | <№>\n| <[[Гравець]]>...
    -- Регулярний вираз: знайти |- або | + будь-які символи (.-) + посилання на гравця + будь-які символи до кінця рядка (\n)
      
      
     -- Використовуємо більш гнучкий пошук, очікуючи на |...||...||
     -- Шукаємо: |- + (.-) (вміст рядка)
   
    -- Оскільки кожна комірка починається з \n|, ми спрощуємо пошук гравця в його комірці:
    local row_pattern_link = "[|]%s*([%d%-]+)%s*[%|%s*]*[%|]%s*%[%[" .. escaped_player .. "%]%](.-)[|]"
     local search_pattern = "([|]%s*%d+%s*[|]%s*" .. player_link_pattern .. ".-[|])"
     local row_pattern_plain = "[|]%s*([%d%-]+)%s*[%|%s*]*[%|]%s*" .. escaped_player .. "%s*[%|](.-)[|]"
   
    local match = mw.ustring.match(table_content, row_pattern_link) or mw.ustring.match(table_content, row_pattern_plain)
      
      
     if not match then
     -- Оскільки ви використовуєте формат: \n| <Значення>, ми шукаємо рядок, що починається з першої комірки (| №)
        return nil
    -- і закінчується останньою коміркою цього рядка.
     end
     -- Знайдемо комірку з гравцем, а потім повернемося до початку рядка (|-).


     -- Витягуємо весь рядок (після |-) для надійного розділення.
     local row_pattern_link = "(|%s*.-[|]%s*" .. player_link_pattern .. ".-[|])"
    -- Ми шукаємо |000||[[Демон]]||29.12.2022||...
     local full_row_match = mw.ustring.match(table_content, row_pattern_link)
    -- УВАГА: Нам потрібно знайти рядок, що починається з | і містить гравця.
   
    local search_pattern = "([|]%s*.-" .. player_link_pattern .. ".-[|])"
     local full_row_match = mw.ustring.match(table_content, search_pattern)
      
      
     if not full_row_match then
     if not full_row_match then
Рядок 47: Рядок 47:
     end
     end
      
      
     local cells = {}
     local columns = {}
   
    -- РОЗДІЛЕННЯ: Тепер розділяємо вміст, використовуючи || як основний роздільник.
    -- Спочатку замінюємо || на | для стандартизації обробки,
    -- але тільки якщо вміст не є посиланням, яке містить || у назві (малоймовірно).
      
      
     local normalized_row = mw.ustring.gsub(full_row_match, "||", "|")
     -- 3. Розділяємо рядок за одинарним |
    -- Ми шукаємо кожну частину, що починається з |, у знайденому рядку
      
      
    -- Якщо рядок починається з |-, видалимо його, щоб не плутати з коміркою.
     for cell in mw.ustring.gmatch(full_row_match, "[|](.-)") do
    normalized_row = mw.ustring.gsub(normalized_row, "^[%s|]*-", "")
         local trimmed_cell = mw.text.trim(cell)
   
        -- Ігноруємо порожні або службові комірки (наприклад, після |-)
    -- Розділяємо за |
        if trimmed_cell ~= "" and trimmed_cell ~= "-" then
     for cell in mw.ustring.gmatch(normalized_row, "[|](.-)") do
            table.insert(columns, trimmed_cell)
         table.insert(cells, mw.text.trim(cell))
        end
     end
     end
    -- Перевіряємо, чи є в колонках службовий елемент "№" або "Пан/Пані" і видаляємо їх.
    -- У цьому форматі columns[1] має бути №, columns[2] - Гравець
      
      
    -- Індекси: cells[1] = Нумерація, cells[2] = Гравець, cells[3] = Дані 1 (Дата), cells[4] = Дані 2 (Провідник)
     local result = columns[column_index]
   
     local result = cells[column_index]


     if result then
     if result then
        -- Очищуємо від зовнішніх [[ та ]]
         result = mw.text.trim(mw.ustring.gsub(result, "%[?%[?(.+)%]%]?", "%1"))
         result = mw.text.trim(mw.ustring.gsub(result, "%[?%[?(.+)%]%]?", "%1"))
         return result
         return result
Рядок 74: Рядок 73:
     end
     end
end
end
--- Функції, що викликаються шаблоном MCC Player New ---


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


Рядок 83: Рядок 85:
     end
     end


    -- Парсинг дати у форматі DD.MM.YYYY
     local day, month, year = mw.ustring.match(date_str, "(%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)")
      
      
Рядок 104: Рядок 107:
function p.recruiter(frame)
function p.recruiter(frame)
     local player = frame.args.player
     local player = frame.args.player
     local recruiter_name = fetch_data.from_table("Гравці", player, 4)
    -- Колонка 4 для Провідника
     local recruiter_name = fetch_data_from_table("Гравці", player, 4)


     if not recruiter_name or recruiter_name == "" or recruiter_name == "Не вказано" or recruiter_name == "-" then
     if not recruiter_name or recruiter_name == "" or recruiter_name == "Не вказано" or recruiter_name == "-" or recruiter_name == "Відсутній" then
         return "Не вказано"
         return "Не вказано"
     end
     end
      
      
    -- Перевірка, чи це вже вікі-посилання (щоб не додавати зайвих [[)
     if mw.ustring.match(recruiter_name, "%[?%[?") then
     if mw.ustring.match(recruiter_name, "%[?%[?") then
         return recruiter_name
         return recruiter_name
Рядок 119: Рядок 124:
function p.prize_pool(frame)
function p.prize_pool(frame)
     local player = frame.args.player
     local player = frame.args.player
    -- Колонка 3 для Суми
     local amount = fetch_data_from_table("Призовий_фонд", player, 3)
     local amount = fetch_data_from_table("Призовий_фонд", player, 3)


Рядок 125: Рядок 131:
     end
     end


    -- Очищення від символів валют та пробілів
     amount = mw.ustring.gsub(amount, "[^%d%s]", "")
     amount = mw.ustring.gsub(amount, "[^%d%s]", "")
     amount = mw.text.trim(amount)
     amount = mw.text.trim(amount)
Рядок 133: Рядок 140:
function p.foundation(frame)
function p.foundation(frame)
     local player = frame.args.player
     local player = frame.args.player
     local amount = fetch_data.from_table("Фундація", player, 3)
    -- Колонка 3 для Суми
     local amount = fetch_data_from_table("Фундація", player, 3)


     if not amount or amount == "" then
     if not amount or amount == "" then
Рядок 147: Рядок 155:
function p.final(frame)
function p.final(frame)
     local player = frame.args.player
     local player = frame.args.player
    -- Колонка 3 для Кількість/Рахунок
     local count = fetch_data_from_table("Фіналіст", player, 3)
     local count = fetch_data_from_table("Фіналіст", player, 3)


Рядок 153: Рядок 162:
     end
     end


    -- Вилучення лише числа з рядка (на випадок, якщо там записано "3/9")
     count = mw.ustring.match(count, "(%d+)")
     count = mw.ustring.match(count, "(%d+)")
      
      

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

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

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}) 

--- Функція для вилучення даних з вказаної сторінки та колонки
-- @param page_title Назва сторінки (наприклад, "Гравці")
-- @param player_name Ім'я гравця для пошуку
-- @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 content = title and title:getContent()

    if not content then
        return nil
    end

    -- 1. Вилучити вміст таблиці wikitable
    -- Використовуємо нежадібний пошук (.-?) між {| і |}
    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")
    local player_link_pattern = "%[?%[" .. escaped_player .. "%]%]?"

    -- 2. Знайти повний рядок, що містить гравця. 
    -- Ми шукаємо | <№>\n| <[[Гравець]]>...
    -- Регулярний вираз: знайти |- або | + будь-які символи (.-) + посилання на гравця + будь-які символи до кінця рядка (\n)
    
    -- Шукаємо: |- + (.-) (вміст рядка)
    -- Оскільки кожна комірка починається з \n|, ми спрощуємо пошук гравця в його комірці:
    local search_pattern = "([|]%s*%d+%s*[|]%s*" .. player_link_pattern .. ".-[|])"
    
    -- Оскільки ви використовуєте формат: \n| <Значення>, ми шукаємо рядок, що починається з першої комірки (| №)
    -- і закінчується останньою коміркою цього рядка.
    -- Знайдемо комірку з гравцем, а потім повернемося до початку рядка (|-).

    local row_pattern_link = "(|%s*.-[|]%s*" .. player_link_pattern .. ".-[|])"
    local full_row_match = mw.ustring.match(table_content, row_pattern_link)
    
    if not full_row_match then
        return nil
    end
    
    local columns = {}
    
    -- 3. Розділяємо рядок за одинарним |
    -- Ми шукаємо кожну частину, що починається з |, у знайденому рядку
    
    for cell in mw.ustring.gmatch(full_row_match, "[|](.-)") do
        local trimmed_cell = mw.text.trim(cell)
        -- Ігноруємо порожні або службові комірки (наприклад, після |-)
        if trimmed_cell ~= "" and trimmed_cell ~= "-" then
            table.insert(columns, trimmed_cell)
        end
    end

    -- Перевіряємо, чи є в колонках службовий елемент "№" або "Пан/Пані" і видаляємо їх.
    -- У цьому форматі columns[1] має бути №, columns[2] - Гравець
    
    local result = columns[column_index]

    if result then
        -- Очищуємо від зовнішніх [[ та ]]
        result = mw.text.trim(mw.ustring.gsub(result, "%[?%[?(.+)%]%]?", "%1"))
        return result
    else
        return nil
    end
end

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

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

    if not date_str or date_str == "" then
        return "''Невідомо''"
    end

    -- Парсинг дати у форматі DD.MM.YYYY
    local day, month, year = mw.ustring.match(date_str, "(%d%d)%.(%d%d)%.(%d%d%d%d)")
    
    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 diff_seconds = TARGET_TIMESTAMP - join_timestamp
    
    if diff_seconds < 0 then
        return date_str
    end

    local diff_days = math.floor(diff_seconds / 86400)
    
    return string.format("%s (%d д)", date_str, diff_days)
end

function p.recruiter(frame)
    local player = frame.args.player
    -- Колонка 4 для Провідника
    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

function p.prize_pool(frame)
    local player = frame.args.player
    -- Колонка 3 для Суми
    local amount = fetch_data_from_table("Призовий_фонд", player, 3)

    if not amount or amount == "" then
        return "0 ₴"
    end

    -- Очищення від символів валют та пробілів
    amount = mw.ustring.gsub(amount, "[^%d%s]", "")
    amount = mw.text.trim(amount)
    
    return amount .. " ₴"
end

function p.foundation(frame)
    local player = frame.args.player
    -- Колонка 3 для Суми
    local amount = fetch_data_from_table("Фундація", player, 3)

    if not amount or amount == "" then
        return "0 ₴"
    end

    amount = mw.ustring.gsub(amount, "[^%d%s]", "")
    amount = mw.text.trim(amount)
    
    return amount .. " ₴"
end

function p.final(frame)
    local player = frame.args.player
    -- Колонка 3 для Кількість/Рахунок
    local count = fetch_data_from_table("Фіналіст", player, 3)

    if not count or count == "" then
        return "0/9"
    end

    -- Вилучення лише числа з рядка (на випадок, якщо там записано "3/9")
    count = mw.ustring.match(count, "(%d+)")
    
    if not count then
         return "0/9"
    end
    
    return count .. "/9"
end

return p