Module:Team: Difference between revisions
From eSportsAmaze
More actions
Esportsamaze (talk | contribs) No edit summary |
Esportsamaze (talk | contribs) No edit summary |
||
| Line 5: | Line 5: | ||
-- ============================================================ | -- ============================================================ | ||
-- HELPER FUNCTIONS | -- HELPER FUNCTIONS | ||
-- ============================================================ | -- ============================================================ | ||
| Line 49: | Line 49: | ||
-- ============================================================ | -- ============================================================ | ||
-- MAIN 1: TEAM INFOBOX ( | -- MAIN 1: TEAM INFOBOX (Unchanged) | ||
-- ============================================================ | -- ============================================================ | ||
function p.infobox(frame) | function p.infobox(frame) | ||
| Line 102: | Line 102: | ||
-- ============================================================ | -- ============================================================ | ||
-- MAIN 2: HYBRID ACTIVE ROSTER ( | -- MAIN 2: HYBRID ACTIVE ROSTER (New Hero Grid) | ||
-- ============================================================ | -- ============================================================ | ||
function p.roster(frame) | function p.roster(frame) | ||
| Line 137: | Line 137: | ||
end | end | ||
-- Check manual args (player1, player2...) | -- Check manual args (player1, player2... up to 10) | ||
for i = 1, 10 do | for i = 1, 10 do | ||
local mid = args['player' .. i] | local mid = args['player' .. i] | ||
| Line 156: | Line 156: | ||
end | end | ||
-- 3. Render the Grid ( | -- 3. Render the Grid (Using 'hero-' classes) | ||
local grid = html.create('div'):addClass('hero-roster-grid') | local grid = html.create('div'):addClass('hero-roster-grid') | ||
| Line 204: | Line 204: | ||
-- ============================================================ | -- ============================================================ | ||
-- MAIN 3: FORMER PLAYERS LIST | -- MAIN 3: FORMER PLAYERS LIST (New Table) | ||
-- ============================================================ | -- ============================================================ | ||
function p.formerPlayers(frame) | function p.formerPlayers(frame) | ||
| Line 244: | Line 244: | ||
-- ============================================================ | -- ============================================================ | ||
-- MAIN 4: | -- MAIN 4: HISTORY (Preserved from your code) | ||
-- ============================================================ | -- ============================================================ | ||
function p. | function p.history(frame) | ||
local args = frame:getParent().args | local args = frame:getParent().args | ||
local team = args.team or | local team = args.team or mw.title.getCurrentTitle().subpageText | ||
local results = cargo.query("StageStandings", "tournament, stage, totalpts, matchesplayed, wwcd, elimpts, lastmatchrank, result", { | |||
where = "team = '" .. team:gsub("'", "\\'") .. "'", | |||
orderBy = "tournament DESC", | |||
limit = 50 | |||
}) | |||
local | local root = html.create('div') | ||
root:wikitext('== Tournament Statistics ==') | |||
local | if #results > 0 then | ||
local tbl = root:tag('table'):addClass('modern-history-table') | |||
local thead = tbl:tag('thead'):tag('tr') | |||
thead:tag('th'):wikitext('Tournament'); thead:tag('th'):wikitext('Stage'); thead:tag('th'):wikitext('Rank') | |||
thead:tag('th'):wikitext('MP'); thead:tag('th'):wikitext('WWCD'); thead:tag('th'):wikitext('Elims'); thead:tag('th'):wikitext('Pts') | |||
for _, row in ipairs(results) do | |||
local tr = tbl:tag('tr') | |||
local res = (row.result or ""):lower() | |||
if res == "q" or res == "qualified" then tr:css('background-color', '#E9FFF0') | |||
elseif res == "e" or res == "eliminated" then tr:css('background-color', '#FFE9E9') end | |||
tr:tag('td'):css('font-weight','bold'):wikitext('[[' .. row.tournament .. ']]') | |||
tr:tag('td'):wikitext(row.stage) | |||
tr:tag('td'):css('font-weight','bold'):css('text-align','center'):wikitext('#' .. (row.lastmatchrank or '?')) | |||
tr:tag('td'):css('text-align','center'):wikitext(row.matchesplayed) | |||
tr:tag('td'):css('text-align','center'):wikitext(row.wwcd) | |||
tr:tag('td'):css('text-align','center'):wikitext(row.elimpts) | |||
tr:tag('td'):css('text-align','center'):css('font-weight','800'):wikitext(row.totalpts) | |||
return tostring( | end | ||
else root:wikitext("''No tournament data found for this team.''") end | |||
return tostring(root) | |||
end | end | ||
return p | return p | ||
Revision as of 20:24, 29 January 2026
Documentation for this module may be created at Module:Team/doc
local p = {}
local cargo = mw.ext.cargo
local html = mw.html
local currentTitle = mw.title.getCurrentTitle()
-- ============================================================
-- HELPER FUNCTIONS
-- ============================================================
local function formatCurrency(amount)
if not amount then return "0" end
local n = tonumber(amount) or 0
local formatted = tostring(n):reverse():gsub("(%d%d%d)(%d%d%d)","%1,%2"):reverse()
return '<span class="indian-currency">₹ ' .. formatted .. '</span>'
end
local function getSocials(args)
local container = html.create('div'):addClass('fib-socials')
local hasSocials = false
local platforms = {
{arg='instagram', file='Icon_instagram.png'},
{arg='twitter', file='Icon_twitter.png'},
{arg='youtube', file='Icon_youtube.png'},
{arg='discord', file='Icon_discord.png'},
{arg='facebook', file='Icon_facebook.png'},
{arg='website', file='Icon_website.png'}
}
for _, p in ipairs(platforms) do
if args[p.arg] and args[p.arg] ~= "" then
hasSocials = true
container:wikitext('[[File:' .. p.file .. '|24px|link=' .. args[p.arg] .. '|class=social-img]]')
end
end
if hasSocials then return tostring(container) else return "" end
end
local function getInfoboxLogo(teamName, image, imageDark)
local lightFile = (image ~= "" and image) or (teamName .. '.png')
local darkFile = (imageDark ~= "" and imageDark) or (teamName .. '_dark.png')
local hasLight = mw.title.new('File:' .. lightFile).exists
local hasDark = mw.title.new('File:' .. darkFile).exists
local container = html.create('div'):addClass('fib-image')
local lSpan = container:tag('span'):addClass('logo-lightmode')
if hasLight then lSpan:wikitext('[[File:' .. lightFile .. '|220px]]') else lSpan:wikitext('[[File:Shield_team.png|180px]]') end
local dSpan = container:tag('span'):addClass('logo-darkmode')
if hasDark then dSpan:wikitext('[[File:' .. darkFile .. '|220px]]') elseif hasLight then dSpan:wikitext('[[File:' .. lightFile .. '|220px]]') else dSpan:wikitext('[[File:Shield_team_dark.png|180px]]') end
return tostring(container)
end
-- ============================================================
-- MAIN 1: TEAM INFOBOX (Unchanged)
-- ============================================================
function p.infobox(frame)
local args = frame:getParent().args
local team = args.name or currentTitle.subpageText
local root = html.create('div'):addClass('flat-infobox')
root:tag('div'):addClass('fib-header'):tag('div'):addClass('fib-title'):wikitext(team)
root:wikitext(getInfoboxLogo(team, args.image, args.image_dark))
local earnings = "0"
if cargo and cargo.query then
local results = cargo.query("PrizeMoney", "SUM(prize)=total", { where = "team = '" .. team:gsub("'", "\\'") .. "' AND (player='' OR player IS NULL)" })
if results and #results > 0 and results[1].total then earnings = results[1].total end
end
local rankVal = "Unranked"
if cargo and cargo.query then
local rResults = cargo.query("Krafton_Rankings", "rank", { where = "name = '" .. team:gsub("'", "\\'") .. "' AND type='Team'", limit = 1 })
if rResults and #rResults > 0 then rankVal = "#" .. rResults[1].rank end
end
local statusColor = "#333"
local statusText = args.status or "Active"
if args.status then
local s = args.status:lower()
if s == "active" then statusColor = "#16a34a" elseif s == "inactive" or s == "disbanded" then statusColor = "#dc2626" end
end
local grid1 = root:tag('div'):addClass('fib-grid')
grid1:tag('div'):addClass('fib-cell'):tag('div'):addClass('fib-label-sm'):wikitext('Status'):done():tag('div'):addClass('fib-value-sm'):css('color', statusColor):wikitext(statusText):done()
grid1:tag('div'):addClass('fib-cell'):tag('div'):addClass('fib-label-sm'):wikitext('Krafton Rank'):done():tag('div'):addClass('fib-value-sm'):wikitext(rankVal):done()
local grid2 = root:tag('div'):addClass('fib-grid')
grid2:tag('div'):addClass('fib-cell'):tag('div'):addClass('fib-label-sm'):wikitext('Country'):done():tag('div'):addClass('fib-value-sm'):wikitext(args.country or 'TBD'):done()
grid2:tag('div'):addClass('fib-cell'):tag('div'):addClass('fib-label-sm'):wikitext('Tag'):done():tag('div'):addClass('fib-value-sm'):wikitext(args.short_code or '-'):done()
if earnings and tonumber(earnings) and tonumber(earnings) > 0 then
root:tag('div'):addClass('fib-prize'):tag('div'):addClass('fib-label-sm'):wikitext('Total Earnings'):done():tag('div'):addClass('fib-prize-val'):wikitext(formatCurrency(earnings)):done()
end
local list = root:tag('div'):addClass('fib-list')
local function addRow(label, value)
if value and value ~= "" then list:tag('div'):addClass('fib-row'):tag('div'):addClass('fib-label'):wikitext(label):done():tag('div'):addClass('fib-data'):wikitext(value):done() end
end
addRow('Full Name', args.other_team)
if args.sponsors then addRow('Sponsors', args.sponsors:gsub(",", "<br>")) end
root:wikitext(getSocials(args))
return tostring(root)
end
-- ============================================================
-- MAIN 2: HYBRID ACTIVE ROSTER (New Hero Grid)
-- ============================================================
function p.roster(frame)
local args = frame:getParent().args
local team = args.team or currentTitle.subpageText
-- 1. Fetch Database Players
local dbPlayers = {}
if cargo and cargo.query then
local tables = "Players"
local fields = "id, real_name, role, nationality, image, _pageName"
local where = "current_team = '" .. team:gsub("'", "\\'") .. "' AND status='Active'"
local results = cargo.query(tables, fields, { where = where, orderBy = "role ASC" })
for _, row in ipairs(results) do
dbPlayers[row.id] = {
id = row.id,
name = row.real_name,
role = row.role,
flag = row.nationality,
image = row.image,
link = row._pageName,
source = "auto"
}
end
end
-- 2. Process Manual Inputs (Check for duplicates)
local finalRoster = {}
-- Add DB players first
for _, pData in pairs(dbPlayers) do
table.insert(finalRoster, pData)
end
-- Check manual args (player1, player2... up to 10)
for i = 1, 10 do
local mid = args['player' .. i]
if mid and mid ~= "" then
-- Only add if NOT in DB list
if not dbPlayers[mid] then
table.insert(finalRoster, {
id = mid,
name = args['name' .. i] or "",
role = args['role' .. i] or "Player",
flag = args['flag' .. i] or "India",
image = "", -- Manual entries usually have no image
link = mid, -- Redlink assumption
source = "manual"
})
end
end
end
-- 3. Render the Grid (Using 'hero-' classes)
local grid = html.create('div'):addClass('hero-roster-grid')
for _, player in ipairs(finalRoster) do
local card = grid:tag('div'):addClass('hero-player-card')
-- Header (Image Area)
local header = card:tag('div'):addClass('hero-card-image')
if player.image and player.image ~= "" then
header:wikitext('[[File:' .. player.image .. '|link=' .. player.link .. ']]')
else
-- Fallback Silhouette
header:wikitext('[[File:Player_Placeholder.png|link=' .. player.link .. ']]')
end
-- Info Body
local body = card:tag('div'):addClass('hero-card-body')
-- Role Pill
local roleColor = "#64748b" -- Default Gray
local r = (player.role or ""):lower()
if r:find("igl") then roleColor = "#eab308" -- Gold
elseif r:find("fragger") or r:find("entry") or r:find("assault") then roleColor = "#ef4444" -- Red
elseif r:find("support") or r:find("medic") then roleColor = "#22c55e" -- Green
elseif r:find("sniper") then roleColor = "#3b82f6" -- Blue
elseif r:find("coach") then roleColor = "#a855f7" -- Purple
end
body:tag('div'):addClass('hero-role-pill')
:css('background-color', roleColor)
:wikitext(player.role or "Player")
-- ID and Name
body:tag('div'):addClass('hero-player-id'):wikitext('[[' .. player.link .. '|' .. player.id .. ']]')
if player.name and player.name ~= "" then
body:tag('div'):addClass('hero-player-name'):wikitext(player.name)
end
-- Flag
if player.flag then
body:tag('div'):addClass('hero-player-flag'):wikitext('[[File:Flag_' .. player.flag .. '.png|20px]] ' .. player.flag)
end
end
return tostring(grid)
end
-- ============================================================
-- MAIN 3: FORMER PLAYERS LIST (New Table)
-- ============================================================
function p.formerPlayers(frame)
local args = frame:getParent().args
local team = args.team or currentTitle.subpageText
local results = cargo.query("Player_Former_Teams, Players",
"Player_Former_Teams.player_id=id, Players.real_name=Name, Player_Former_Teams.role=role, Player_Former_Teams.join_date=join_date, Player_Former_Teams.leave_date=leave_date",
{
joinOn = "Player_Former_Teams.player_id = Players.id",
where = "Player_Former_Teams.team = '" .. team:gsub("'", "\\'") .. "'",
orderBy = "Player_Former_Teams.leave_date DESC"
}
)
if not results or #results == 0 then
return '<div style="font-style:italic; color:#64748b; padding:10px;">No former players recorded.</div>'
end
local tbl = html.create('table'):addClass('wikitable flat-table sortable'):css('width','100%')
local h = tbl:tag('tr')
h:tag('th'):wikitext('ID')
h:tag('th'):wikitext('Name')
h:tag('th'):wikitext('Role')
h:tag('th'):wikitext('Join Date')
h:tag('th'):wikitext('Leave Date')
for _, row in ipairs(results) do
local tr = tbl:tag('tr')
tr:tag('td'):css('font-weight','bold'):wikitext('[[' .. row.id .. ']]')
tr:tag('td'):wikitext(row.Name or "-")
tr:tag('td'):wikitext(row.role or "-")
tr:tag('td'):wikitext(row.join_date or "?")
tr:tag('td'):wikitext(row.leave_date or "?")
end
return tostring(tbl)
end
-- ============================================================
-- MAIN 4: HISTORY (Preserved from your code)
-- ============================================================
function p.history(frame)
local args = frame:getParent().args
local team = args.team or mw.title.getCurrentTitle().subpageText
local results = cargo.query("StageStandings", "tournament, stage, totalpts, matchesplayed, wwcd, elimpts, lastmatchrank, result", {
where = "team = '" .. team:gsub("'", "\\'") .. "'",
orderBy = "tournament DESC",
limit = 50
})
local root = html.create('div')
root:wikitext('== Tournament Statistics ==')
if #results > 0 then
local tbl = root:tag('table'):addClass('modern-history-table')
local thead = tbl:tag('thead'):tag('tr')
thead:tag('th'):wikitext('Tournament'); thead:tag('th'):wikitext('Stage'); thead:tag('th'):wikitext('Rank')
thead:tag('th'):wikitext('MP'); thead:tag('th'):wikitext('WWCD'); thead:tag('th'):wikitext('Elims'); thead:tag('th'):wikitext('Pts')
for _, row in ipairs(results) do
local tr = tbl:tag('tr')
local res = (row.result or ""):lower()
if res == "q" or res == "qualified" then tr:css('background-color', '#E9FFF0')
elseif res == "e" or res == "eliminated" then tr:css('background-color', '#FFE9E9') end
tr:tag('td'):css('font-weight','bold'):wikitext('[[' .. row.tournament .. ']]')
tr:tag('td'):wikitext(row.stage)
tr:tag('td'):css('font-weight','bold'):css('text-align','center'):wikitext('#' .. (row.lastmatchrank or '?'))
tr:tag('td'):css('text-align','center'):wikitext(row.matchesplayed)
tr:tag('td'):css('text-align','center'):wikitext(row.wwcd)
tr:tag('td'):css('text-align','center'):wikitext(row.elimpts)
tr:tag('td'):css('text-align','center'):css('font-weight','800'):wikitext(row.totalpts)
end
else root:wikitext("''No tournament data found for this team.''") end
return tostring(root)
end
return p