Toggle menu
Toggle preferences menu
Toggle personal menu
Not logged in
Your IP address will be publicly visible if you make any edits.

Module:Calendar: Difference between revisions

From eSportsAmaze
No edit summary
No edit summary
Line 3: Line 3:


function p.main(frame)
function p.main(frame)
    local args = frame:getParent().args
local args = frame:getParent().args
    local tournament = args.tournament
local tournament = args.tournament
    local game = args.game
local game = args.game
    local stage = args.stage
local stage = args.stage
    local exclude_stage = args.exclude_stage
local exclude_stage = args.exclude_stage


    local whereParts = {}
local whereParts = {}
    if tournament and tournament ~= "" then table.insert(whereParts, "tournament='" .. tournament:gsub("'", "\\'") .. "'") end
if tournament and tournament ~= "" then table.insert(whereParts, "tournament='" .. tournament:gsub("'", "\\'") .. "'") end
    if game and game ~= "" then table.insert(whereParts, "game='" .. game:gsub("'", "\\'") .. "'") end
if game and game ~= "" then table.insert(whereParts, "game='" .. game:gsub("'", "\\'") .. "'") end
   
    if stage and stage ~= "" then
        table.insert(whereParts, "stage='" .. stage:gsub("'", "\\'") .. "'")
    end
    if exclude_stage and exclude_stage ~= "" then
        table.insert(whereParts, "stage!='" .. exclude_stage:gsub("'", "\\'") .. "'")
    end


    local whereClause = table.concat(whereParts, " AND ")
if stage and stage ~= "" then
    if whereClause == "" then whereClause = "1=1" end
table.insert(whereParts, "stage='" .. stage:gsub("'", "\\'") .. "'")  
end
if exclude_stage and exclude_stage ~= "" then  
table.insert(whereParts, "stage!='" .. exclude_stage:gsub("'", "\\'") .. "'")
end


    local results = cargo.query("Tournament_Schedule", "tournament, game, match_type, date, stage, day_data", { where = whereClause, orderBy = "date ASC", limit = 500 })
local whereClause = table.concat(whereParts, " AND ")
if whereClause == "" then whereClause = "1=1" end


    if not results or #results == 0 then
-- ADDED STREAM TO QUERY
        return "<div style='padding:20px; text-align:center; color:var(--text-muted); background:var(--bg-card); border-radius:8px; border:1px solid var(--border-light);'>No schedule data found. Add matches using the MatchDay template.</div>"
local results = cargo.query("Tournament_Schedule", "tournament, game, match_type, date, stage, stream, day_data", { where = whereClause, orderBy = "date ASC", limit = 500 })
    end


    local scheduleByDate = {}
if not results or #results == 0 then
    for _, row in ipairs(results) do
return "<div style='padding:20px; text-align:center; color:var(--text-muted); background:var(--bg-card); border-radius:8px; border:1px solid var(--border-light);'>No schedule data found. Add matches using the MatchDay template.</div>"
        local d = row.date
end
        if not scheduleByDate[d] then scheduleByDate[d] = {} end
        table.insert(scheduleByDate[d], {
            tournament = row.tournament, game = row.game, match_type = row.match_type, stage = row.stage,
            data = mw.text.jsonDecode(row.day_data)
        })
    end


    local jsonString = mw.text.jsonEncode(scheduleByDate)
local scheduleByDate = {}
    local root = mw.html.create('div'):addClass('esports-calendar-container')
for _, row in ipairs(results) do
local d = row.date
if not scheduleByDate[d] then scheduleByDate[d] = {} end
table.insert(scheduleByDate[d], {
tournament = row.tournament, game = row.game, match_type = row.match_type, stage = row.stage, stream = row.stream,
data = mw.text.jsonDecode(row.day_data)
})
end


    root:tag('div'):addClass('calendar-data'):css('display', 'none'):wikitext(jsonString)
local jsonString = mw.text.jsonEncode(scheduleByDate)
local root = mw.html.create('div'):addClass('esports-calendar-container')


    local calLeft = root:tag('div'):addClass('calendar-left')
root:tag('div'):addClass('calendar-data'):css('display', 'none'):wikitext(jsonString)
    local header = calLeft:tag('div'):addClass('calendar-header')
   
    header:tag('div'):addClass('cal-prev'):wikitext('&#10094;')
    header:tag('div'):addClass('cal-month-year'):wikitext('Loading...')
    header:tag('div'):addClass('cal-next'):wikitext('&#10095;')


    local gridWrap = calLeft:tag('div'):addClass('calendar-grid-wrapper')
local calLeft = root:tag('div'):addClass('calendar-left')
    -- CHANGED: Now starts with Monday
local header = calLeft:tag('div'):addClass('calendar-header')
    gridWrap:tag('div'):addClass('calendar-grid-days'):wikitext('<div>Mon</div><div>Tue</div><div>Wed</div><div>Thu</div><div>Fri</div><div>Sat</div><div>Sun</div>')
    gridWrap:tag('div'):addClass('calendar-grid-dates')


    local calRight = root:tag('div'):addClass('calendar-right')
header:tag('div'):addClass('cal-prev'):wikitext('&#10094;')
    calRight:tag('div'):addClass('cal-details-content')
header:tag('div'):addClass('cal-month-year'):wikitext('Loading...')
header:tag('div'):addClass('cal-next'):wikitext('&#10095;')


    return tostring(root)
local gridWrap = calLeft:tag('div'):addClass('calendar-grid-wrapper')
gridWrap:tag('div'):addClass('calendar-grid-days'):wikitext('<div>Mon</div><div>Tue</div><div>Wed</div><div>Thu</div><div>Fri</div><div>Sat</div><div>Sun</div>')
gridWrap:tag('div'):addClass('calendar-grid-dates')
 
local calRight = root:tag('div'):addClass('calendar-right')
calRight:tag('div'):addClass('cal-details-content')
 
return tostring(root)
end
end


return p
return p

Revision as of 02:41, 23 February 2026

Documentation for this module may be created at Module:Calendar/doc

local p = {}
local cargo = mw.ext.cargo

function p.main(frame)
local args = frame:getParent().args
local tournament = args.tournament
local game = args.game
local stage = args.stage
local exclude_stage = args.exclude_stage

local whereParts = {}
if tournament and tournament ~= "" then table.insert(whereParts, "tournament='" .. tournament:gsub("'", "\\'") .. "'") end
if game and game ~= "" then table.insert(whereParts, "game='" .. game:gsub("'", "\\'") .. "'") end

if stage and stage ~= "" then 
table.insert(whereParts, "stage='" .. stage:gsub("'", "\\'") .. "'") 
end
if exclude_stage and exclude_stage ~= "" then 
table.insert(whereParts, "stage!='" .. exclude_stage:gsub("'", "\\'") .. "'") 
end

local whereClause = table.concat(whereParts, " AND ")
if whereClause == "" then whereClause = "1=1" end

-- ADDED STREAM TO QUERY
local results = cargo.query("Tournament_Schedule", "tournament, game, match_type, date, stage, stream, day_data", { where = whereClause, orderBy = "date ASC", limit = 500 })

if not results or #results == 0 then
return "<div style='padding:20px; text-align:center; color:var(--text-muted); background:var(--bg-card); border-radius:8px; border:1px solid var(--border-light);'>No schedule data found. Add matches using the MatchDay template.</div>"
end

local scheduleByDate = {}
for _, row in ipairs(results) do
local d = row.date
if not scheduleByDate[d] then scheduleByDate[d] = {} end
table.insert(scheduleByDate[d], {
tournament = row.tournament, game = row.game, match_type = row.match_type, stage = row.stage, stream = row.stream,
data = mw.text.jsonDecode(row.day_data)
})
end

local jsonString = mw.text.jsonEncode(scheduleByDate)
local root = mw.html.create('div'):addClass('esports-calendar-container')

root:tag('div'):addClass('calendar-data'):css('display', 'none'):wikitext(jsonString)

local calLeft = root:tag('div'):addClass('calendar-left')
local header = calLeft:tag('div'):addClass('calendar-header')

header:tag('div'):addClass('cal-prev'):wikitext('&#10094;')
header:tag('div'):addClass('cal-month-year'):wikitext('Loading...')
header:tag('div'):addClass('cal-next'):wikitext('&#10095;')

local gridWrap = calLeft:tag('div'):addClass('calendar-grid-wrapper')
gridWrap:tag('div'):addClass('calendar-grid-days'):wikitext('<div>Mon</div><div>Tue</div><div>Wed</div><div>Thu</div><div>Fri</div><div>Sat</div><div>Sun</div>')
gridWrap:tag('div'):addClass('calendar-grid-dates')

local calRight = root:tag('div'):addClass('calendar-right')
calRight:tag('div'):addClass('cal-details-content')

return tostring(root)
end

return p