From d178f3672879efedcf6a98cf7b2bad0f9d66bd25 Mon Sep 17 00:00:00 2001
From: hjpalpha <75081997+hjpalpha@users.noreply.github.com>
Date: Wed, 4 Oct 2023 14:01:19 +0200
Subject: [PATCH] Update dota, lol and splatoon MatchSummary (#3334)
* remove leading underscore from const vars
* lol
* fix width (lol)
* dota2
* require correct module & remove unused requires & shut up anno
* splatoon
* as per review in #3330
---
.../match2/wikis/dota2/match_summary.lua | 150 ++++++++----------
.../wikis/leagueoflegends/match_summary.lua | 133 +++++++---------
.../match2/wikis/splatoon/match_summary.lua | 111 ++++++-------
3 files changed, 171 insertions(+), 223 deletions(-)
diff --git a/components/match2/wikis/dota2/match_summary.lua b/components/match2/wikis/dota2/match_summary.lua
index 1ccb6fa3c02..720bbdf56b5 100644
--- a/components/match2/wikis/dota2/match_summary.lua
+++ b/components/match2/wikis/dota2/match_summary.lua
@@ -15,21 +15,19 @@ local HeroIcon = require('Module:HeroIcon')
local Table = require('Module:Table')
local String = require('Module:StringUtils')
local Array = require('Module:Array')
-local VodLink = require('Module:VodLink')
local DisplayHelper = Lua.import('Module:MatchGroup/Display/Helper', {requireDevIfEnabled = true})
-local MatchGroupUtil = Lua.import('Module:MatchGroup/Util', {requireDevIfEnabled = true})
-local MatchSummary = Lua.import('Module:MatchSummary/Base', {requireDevIfEnabled = true})
+local MatchSummary = Lua.import('Module:MatchSummary/Base/temp', {requireDevIfEnabled = true})
local Opponent = Lua.import('Module:Opponent', {requireDevIfEnabled = true})
-local _MAX_NUM_BANS = 7
-local _NUM_HEROES_PICK_TEAM = 5
-local _NUM_HEROES_PICK_SOLO = 1
-local _SIZE_HERO = '57x32px'
-local _GREEN_CHECK = '[[File:GreenCheck.png|14x14px|link=]]'
-local _NO_CHECK = '[[File:NoCheck.png|link=]]'
+local MAX_NUM_BANS = 7
+local NUM_HEROES_PICK_TEAM = 5
+local NUM_HEROES_PICK_SOLO = 1
+local SIZE_HERO = '57x32px'
+local GREEN_CHECK = '[[File:GreenCheck.png|14x14px|link=]]'
+local NO_CHECK = '[[File:NoCheck.png|link=]]'
-- Normal links, from input/lpdb
-local _LINK_DATA = {
+local LINK_DATA = {
vod = {icon = 'File:VOD Icon.png', text = 'Watch VOD'},
preview = {icon = 'File:Preview Icon32.png', text = 'Preview'},
lrthread = {icon = 'File:LiveReport32.png', text = 'Live Report Thread'},
@@ -38,7 +36,7 @@ local _LINK_DATA = {
faceit = {icon = 'File:FACEIT-icon.png', text = 'FACEIT match room'},
}
-- Auto generated links from Publisher ID
-local _AUTO_LINKS = {
+local AUTO_LINKS = {
{icon = 'File:DOTABUFF-icon.png', url = 'https://www.dotabuff.com/matches/', name = 'DOTABUFF'},
{icon = 'File:DatDota-icon.png', url = 'https://www.datdota.com/matches/', name = 'datDota'},
{
@@ -49,10 +47,14 @@ local _AUTO_LINKS = {
},
}
-local _EPOCH_TIME = '1970-01-01 00:00:00'
-local _EPOCH_TIME_EXTENDED = '1970-01-01T00:00:00+00:00'
+local EPOCH_TIME = '1970-01-01 00:00:00'
+local EPOCH_TIME_EXTENDED = '1970-01-01T00:00:00+00:00'
-- Hero Ban Class
+---@class DotaHeroBan: MatchSummaryRowInterface
+---@operator call: DotaHeroBan
+---@field root Html
+---@field table Html
local HeroBan = Class.new(
function(self)
self.root = mw.html.create('div'):addClass('brkts-popup-mapveto')
@@ -62,6 +64,7 @@ local HeroBan = Class.new(
end
)
+---@return self
function HeroBan:createHeader()
self.table:tag('tr')
:tag('th'):css('width','35%'):wikitext(''):done()
@@ -70,6 +73,10 @@ function HeroBan:createHeader()
return self
end
+---@param banData {numberOfBans: integer, [1]: table, [2]: table}
+---@param gameNumber integer
+---@param numberOfBans integer
+---@return self
function HeroBan:banRow(banData, gameNumber, numberOfBans)
self.table:tag('tr')
:tag('td'):attr('rowspan', '2'):node(mw.html.create('div')
@@ -88,36 +95,23 @@ function HeroBan:banRow(banData, gameNumber, numberOfBans)
return self
end
+---@return Html
function HeroBan:create()
return self.root
end
-
+---@param args table
+---@return Html
function CustomMatchSummary.getByMatchId(args)
- local match = MatchGroupUtil.fetchMatchForBracketDisplay(args.bracketId, args.matchId)
-
- local matchSummary = MatchSummary():init('400px')
-
- matchSummary:header(CustomMatchSummary._createHeader(match))
- :body(CustomMatchSummary._createBody(match))
-
- if match.comment then
- local comment = MatchSummary.Comment():content(match.comment)
- matchSummary:comment(comment)
- end
+ return MatchSummary.defaultGetByMatchId(CustomMatchSummary, args, {width = '400px'})
+end
- local vods = {}
- local publisherids = {}
- for index, game in ipairs(match.games) do
- if not Logic.isEmpty(game.vod) then
- vods[index] = game.vod
- end
- if not String.isEmpty(game.extradata.publisherid) then
- publisherids[index] = game.extradata.publisherid
- end
- end
+---@param match MatchGroupUtilMatch
+---@param footer MatchSummaryFooter
+---@return MatchSummaryFooter
+function CustomMatchSummary.addToFooter(match, footer)
+ footer = MatchSummary.addVodsToFooter(match, footer)
- match.links.vod = match.vod
if
Logic.readBool(match.extradata.headtohead) and
match.opponents[1].type == Opponent.team and
@@ -128,49 +122,29 @@ function CustomMatchSummary.getByMatchId(args)
'?pfRunQueryFormName=Match+history&Head_to_head_query%5Bplayer%5D=' .. team1 ..
'&Head_to_head_query%5Bopponent%5D=' .. team2 .. '&wpRunQuery=Run+query'
end
- if not Table.isEmpty(vods) or not Table.isEmpty(publisherids) or not Table.isEmpty(match.links) then
- local footer = MatchSummary.Footer()
-
- -- Game Vods
- for index, vod in pairs(vods) do
- footer:addElement(VodLink.display{
- gamenum = index,
- vod = vod,
- source = vod.url
- })
- end
-
- for _, site in ipairs(_AUTO_LINKS) do
- for index, publisherid in pairs(publisherids) do
- local link = site.url .. publisherid
- local text = 'Game '..index..' on '.. site.name
- footer:addLink(link, site.icon, site.iconDark, text)
- end
- end
-
- footer:addLinks(_LINK_DATA, match.links)
-
- matchSummary:footer(footer)
- end
- return matchSummary:create()
-end
+ local publisherIds = {}
+ Array.forEach(match.games, function(game, gameIndex)
+ publisherIds[gameIndex] = Logic.emptyOr(game.extradata.publisherid)
+ end)
-function CustomMatchSummary._createHeader(match)
- local header = MatchSummary.Header()
-
- header:leftOpponent(header:createOpponent(match.opponents[1], 'left', 'bracket'))
- :leftScore(header:createScore(match.opponents[1]))
- :rightScore(header:createScore(match.opponents[2]))
- :rightOpponent(header:createOpponent(match.opponents[2], 'right', 'bracket'))
+ Array.forEach(AUTO_LINKS, function(siteData)
+ for index, publisherId in pairs(publisherIds) do
+ local link = siteData.url .. publisherId
+ local text = 'Game ' .. index .. ' on ' .. siteData.name
+ footer:addLink(link, siteData.icon, siteData.iconDark, text)
+ end
+ end)
- return header
+ return footer:addLinks(LINK_DATA, match.links)
end
-function CustomMatchSummary._createBody(match)
+---@param match MatchGroupUtilMatch
+---@return MatchSummaryBody
+function CustomMatchSummary.createBody(match)
local body = MatchSummary.Body()
- if match.dateIsExact or (match.date ~= _EPOCH_TIME_EXTENDED and match.date ~= _EPOCH_TIME) then
+ if match.dateIsExact or (match.date ~= EPOCH_TIME_EXTENDED and match.date ~= EPOCH_TIME) then
-- dateIsExact means we have both date and time. Show countdown
-- if match is not epoch=0, we have a date, so display the date
body:addRow(MatchSummary.Row():addElement(
@@ -202,10 +176,10 @@ function CustomMatchSummary._createBody(match)
-- Pre-Process Hero Ban Data
local showGameBans = {}
for gameIndex, game in ipairs(match.games) do
- local extradata = game.extradata
+ local extradata = game.extradata or {}
local banData = {{}, {}}
local numberOfBans = 0
- for index = 1, _MAX_NUM_BANS do
+ for index = 1, MAX_NUM_BANS do
if String.isNotEmpty(extradata['team1ban' .. index]) then
numberOfBans = index
banData[1][index] = extradata['team1ban' .. index]
@@ -241,13 +215,16 @@ function CustomMatchSummary._createBody(match)
return body
end
+---@param game MatchGroupUtilGame
+---@param gameIndex integer
+---@return MatchSummaryRow
function CustomMatchSummary._createGame(game, gameIndex)
local row = MatchSummary.Row()
local extradata = game.extradata or {}
- local numberOfHeroes = _NUM_HEROES_PICK_TEAM
+ local numberOfHeroes = NUM_HEROES_PICK_TEAM
if game.mode == Opponent.solo then
- numberOfHeroes = _NUM_HEROES_PICK_SOLO
+ numberOfHeroes = NUM_HEROES_PICK_SOLO
end
local heroesData = {{}, {}}
for heroIndex = 1, numberOfHeroes do
@@ -270,8 +247,8 @@ function CustomMatchSummary._createGame(game, gameIndex)
row:addElement(mw.html.create('div')
:addClass('brkts-popup-body-element-vertical-centered')
:wikitext(CustomMatchSummary._createAbbreviation{
- title = String.isEmpty(game.length) and ('Game ' .. gameIndex .. ' picks') or 'Match Length',
- text = String.isEmpty(game.length) and ('Game ' .. gameIndex) or game.length,
+ title = Logic.isEmpty(game.length) and ('Game ' .. gameIndex .. ' picks') or 'Match Length',
+ text = Logic.isEmpty(game.length) and ('Game ' .. gameIndex) or game.length,
})
)
row:addElement(CustomMatchSummary._createCheckMark(game.winner == 2))
@@ -289,6 +266,8 @@ function CustomMatchSummary._createGame(game, gameIndex)
return row
end
+---@param isWinner boolean?
+---@return Html
function CustomMatchSummary._createCheckMark(isWinner)
local container = mw.html.create('div')
:addClass('brkts-popup-spaced')
@@ -297,18 +276,25 @@ function CustomMatchSummary._createCheckMark(isWinner)
:css('margin-right', '1%')
if Logic.readBool(isWinner) then
- container:node(_GREEN_CHECK)
+ container:node(GREEN_CHECK)
else
- container:node(_NO_CHECK)
+ container:node(NO_CHECK)
end
return container
end
+---@param args table
+---@return string
function CustomMatchSummary._createAbbreviation(args)
return '' .. args.text .. ''
end
+---@param opponentHeroesData table
+---@param numberOfHeroes integer
+---@param flip boolean?
+---@param isBan boolean?
+---@return Html
function CustomMatchSummary._opponentHeroesDisplay(opponentHeroesData, numberOfHeroes, flip, isBan)
local opponentHeroesDisplay = {}
local color = opponentHeroesData.side or ''
@@ -320,9 +306,9 @@ function CustomMatchSummary._opponentHeroesDisplay(opponentHeroesData, numberOfH
:addClass('brkts-popup-side-hero-hover')
:node(HeroIcon._getImage{
hero = opponentHeroesData[index],
- size = _SIZE_HERO,
+ size = SIZE_HERO,
})
- if numberOfHeroes == _NUM_HEROES_PICK_SOLO then
+ if numberOfHeroes == NUM_HEROES_PICK_SOLO then
if flip then
heroDisplay:css('margin-right', '70px')
else
diff --git a/components/match2/wikis/leagueoflegends/match_summary.lua b/components/match2/wikis/leagueoflegends/match_summary.lua
index d27cc961588..46c7b39c4c2 100644
--- a/components/match2/wikis/leagueoflegends/match_summary.lua
+++ b/components/match2/wikis/leagueoflegends/match_summary.lua
@@ -8,30 +8,33 @@
local CustomMatchSummary = {}
+local Array = require('Module:Array')
local Class = require('Module:Class')
local DateExt = require('Module:Date/Ext')
+local HeroIcon = require('Module:ChampionIcon')
local Logic = require('Module:Logic')
local Lua = require('Module:Lua')
-local HeroIcon = require('Module:ChampionIcon')
local MatchLinks = mw.loadData('Module:MatchLinks')
-local Table = require('Module:Table')
local String = require('Module:StringUtils')
-local Array = require('Module:Array')
-local VodLink = require('Module:VodLink')
+local Table = require('Module:Table')
local BigMatch = Lua.import('Module:BigMatch', {requireDevIfEnabled = true})
local DisplayHelper = Lua.import('Module:MatchGroup/Display/Helper', {requireDevIfEnabled = true})
-local MatchGroupUtil = Lua.import('Module:MatchGroup/Util', {requireDevIfEnabled = true})
-local MatchSummary = Lua.import('Module:MatchSummary/Base', {requireDevIfEnabled = true})
+local MatchSummary = Lua.import('Module:MatchSummary/Base/temp', {requireDevIfEnabled = true})
local Opponent = Lua.import('Module:Opponent', {requireDevIfEnabled = true})
-local _MAX_NUM_BANS = 7
-local _NUM_HEROES_PICK_TEAM = 5
-local _NUM_HEROES_PICK_SOLO = 1
-local _GREEN_CHECK = '[[File:GreenCheck.png|14x14px|link=]]'
-local _NO_CHECK = '[[File:NoCheck.png|link=]]'
+local MAX_NUM_BANS = 7
+local NUM_HEROES_PICK_TEAM = 5
+local NUM_HEROES_PICK_SOLO = 1
+local GREEN_CHECK = '[[File:GreenCheck.png|14x14px|link=]]'
+local NO_CHECK = '[[File:NoCheck.png|link=]]'
-- Hero Ban Class
+---@class LeagueoOfLegendsHeroBan: MatchSummaryRowInterface
+---@operator call: LeagueoOfLegendsHeroBan
+---@field root Html
+---@field table Html
+---@field date string
local HeroBan = Class.new(
function(self, date)
self.root = mw.html.create('div'):addClass('brkts-popup-mapveto')
@@ -42,6 +45,7 @@ local HeroBan = Class.new(
end
)
+---@return self
function HeroBan:createHeader()
self.table:tag('tr')
:tag('th'):css('width', '40%'):wikitext(''):done()
@@ -50,6 +54,10 @@ function HeroBan:createHeader()
return self
end
+---@param banData {numberOfBans: integer, [1]: table, [2]: table}
+---@param gameNumber integer
+---@param numberOfBans integer
+---@return self
function HeroBan:banRow(banData, gameNumber, numberOfBans)
self.table:tag('tr')
:tag('td'):css('float', 'left')
@@ -65,75 +73,29 @@ function HeroBan:banRow(banData, gameNumber, numberOfBans)
return self
end
+---@return Html
function HeroBan:create()
return self.root
end
-
+---@param args table
+---@return Html
function CustomMatchSummary.getByMatchId(args)
- local match = MatchGroupUtil.fetchMatchForBracketDisplay(args.bracketId, args.matchId)
-
- local matchSummary = MatchSummary():init('400px')
-
- matchSummary:header(CustomMatchSummary._createHeader(match))
- :body(CustomMatchSummary._createBody(match))
-
- if match.comment then
- local comment = MatchSummary.Comment():content(match.comment)
- matchSummary:comment(comment)
- end
-
- local vods = {}
- for index, game in ipairs(match.games) do
- if not Logic.isEmpty(game.vod) then
- vods[index] = game.vod
- end
- end
- match.links.vod = match.vod
-
- if not Table.isEmpty(vods) or not Table.isEmpty(match.links) then
- local footer = MatchSummary.Footer()
-
- -- Match Vod + other links
- local buildLink = function (link, icon, text)
- return '[[File:'..icon..'|link='..link..'|15px|'..text..']]'
- end
-
- for linkType, link in pairs(match.links) do
- if not MatchLinks[linkType] then
- mw.log('Unknown link: ' .. linkType)
- else
- footer:addElement(buildLink(link, MatchLinks[linkType].icon, MatchLinks[linkType].text))
- end
- end
-
- -- Game Vods
- for index, vod in pairs(vods) do
- footer:addElement(VodLink.display{
- gamenum = index,
- vod = vod,
- source = vod.url
- })
- end
-
- matchSummary:footer(footer)
- end
-
- return matchSummary:create()
+ return MatchSummary.defaultGetByMatchId(CustomMatchSummary, args, {width = '400px'})
end
-function CustomMatchSummary._createHeader(match)
- local header = MatchSummary.Header()
-
- header:leftOpponent(header:createOpponent(match.opponents[1], 'left', 'bracket'))
- :leftScore(header:createScore(match.opponents[1]))
- :rightScore(header:createScore(match.opponents[2]))
- :rightOpponent(header:createOpponent(match.opponents[2], 'right', 'bracket'))
+---@param match MatchGroupUtilMatch
+---@param footer MatchSummaryFooter
+---@return MatchSummaryFooter
+function CustomMatchSummary.addToFooter(match, footer)
+ footer = MatchSummary.addVodsToFooter(match, footer)
- return header
+ return footer:addLinks(MatchLinks, match.links)
end
-function CustomMatchSummary._createBody(match)
+---@param match MatchGroupUtilMatch
+---@return MatchSummaryBody
+function CustomMatchSummary.createBody(match)
local body = MatchSummary.Body()
if match.dateIsExact or match.timestamp ~= DateExt.epochZero then
@@ -176,10 +138,10 @@ function CustomMatchSummary._createBody(match)
-- Pre-Process Hero Ban Data
local showGameBans = {}
for gameIndex, game in ipairs(match.games) do
- local extradata = game.extradata
+ local extradata = game.extradata or {}
local banData = {{}, {}}
local numberOfBans = 0
- for index = 1, _MAX_NUM_BANS do
+ for index = 1, MAX_NUM_BANS do
if String.isNotEmpty(extradata['team1ban' .. index]) then
numberOfBans = index
banData[1][index] = extradata['team1ban' .. index]
@@ -215,13 +177,17 @@ function CustomMatchSummary._createBody(match)
return body
end
+---@param game MatchGroupUtilGame
+---@param gameIndex integer
+---@param date string
+---@return MatchSummaryRow
function CustomMatchSummary._createGame(game, gameIndex, date)
local row = MatchSummary.Row()
local extradata = game.extradata or {}
- local numberOfHeroes = _NUM_HEROES_PICK_TEAM
+ local numberOfHeroes = NUM_HEROES_PICK_TEAM
if game.mode == Opponent.solo then
- numberOfHeroes = _NUM_HEROES_PICK_SOLO
+ numberOfHeroes = NUM_HEROES_PICK_SOLO
end
local heroesData = {{}, {}}
@@ -246,8 +212,8 @@ function CustomMatchSummary._createGame(game, gameIndex, date)
row:addElement(mw.html.create('div')
:addClass('brkts-popup-body-element-vertical-centered')
:wikitext(CustomMatchSummary._createAbbreviation{
- title = String.isEmpty(game.length) and ('Game ' .. gameIndex .. ' picks') or 'Match Length',
- text = String.isEmpty(game.length) and ('Game ' .. gameIndex) or game.length,
+ title = Logic.isEmpty(game.length) and ('Game ' .. gameIndex .. ' picks') or 'Match Length',
+ text = Logic.isEmpty(game.length) and ('Game ' .. gameIndex) or game.length,
})
)
row:addElement(CustomMatchSummary._createCheckMark(game.winner == 2))
@@ -265,6 +231,8 @@ function CustomMatchSummary._createGame(game, gameIndex, date)
return row
end
+---@param isWinner boolean?
+---@return Html
function CustomMatchSummary._createCheckMark(isWinner)
local container = mw.html.create('div')
:addClass('brkts-popup-body-element-vertical-centered')
@@ -273,18 +241,25 @@ function CustomMatchSummary._createCheckMark(isWinner)
:css('margin-right', '1%')
if Logic.readBool(isWinner) then
- container:node(_GREEN_CHECK)
+ container:node(GREEN_CHECK)
else
- container:node(_NO_CHECK)
+ container:node(NO_CHECK)
end
return container
end
+---@param args table
+---@return string
function CustomMatchSummary._createAbbreviation(args)
return '' .. args.text .. ''
end
+---@param opponentHeroesData table
+---@param numberOfHeroes integer
+---@param flip boolean?
+---@param date string
+---@return Html
function CustomMatchSummary._opponentHeroesDisplay(opponentHeroesData, numberOfHeroes, flip, date)
local opponentHeroesDisplay = {}
local color = opponentHeroesData.side or ''
@@ -293,7 +268,7 @@ function CustomMatchSummary._opponentHeroesDisplay(opponentHeroesData, numberOfH
local heroDisplay = mw.html.create('div')
:addClass('brkts-popup-side-color-' .. color)
:node(HeroIcon._getImage{opponentHeroesData[index], date = date})
- if numberOfHeroes == _NUM_HEROES_PICK_SOLO then
+ if numberOfHeroes == NUM_HEROES_PICK_SOLO then
if flip then
heroDisplay:css('margin-right', '70px')
else
diff --git a/components/match2/wikis/splatoon/match_summary.lua b/components/match2/wikis/splatoon/match_summary.lua
index d4f97d7e400..c492c6b1978 100644
--- a/components/match2/wikis/splatoon/match_summary.lua
+++ b/components/match2/wikis/splatoon/match_summary.lua
@@ -16,12 +16,10 @@ local Lua = require('Module:Lua')
local MapTypeIcon = require('Module:MapType')
local String = require('Module:StringUtils')
local Table = require('Module:Table')
-local VodLink = require('Module:VodLink')
local WeaponIcon = require('Module:WeaponIcon')
local DisplayHelper = Lua.import('Module:MatchGroup/Display/Helper', {requireDevIfEnabled = true})
-local MatchGroupUtil = Lua.import('Module:MatchGroup/Util', {requireDevIfEnabled = true})
-local MatchSummary = Lua.import('Module:MatchSummary/Base', {requireDevIfEnabled = true})
+local MatchSummary = Lua.import('Module:MatchSummary/Base/temp', {requireDevIfEnabled = true})
local NUM_OPPONENTS = 2
local GREEN_CHECK = '[[File:GreenCheck.png|14x14px|link=]]'
@@ -37,6 +35,10 @@ local LINK_DATA = {
local NON_BREAKING_SPACE = ' '
-- Map Veto Class
+---@class SplatoonMapVeto: MatchSummaryRowInterface
+---@operator call: SplatoonMapVeto
+---@field root Html
+---@field table Html
local MapVeto = Class.new(
function(self)
self.root = mw.html.create('div'):addClass('brkts-popup-mapveto')
@@ -46,6 +48,7 @@ local MapVeto = Class.new(
end
)
+---@return self
function MapVeto:createHeader()
self.table:tag('tr')
:tag('th'):css('width','33%'):done()
@@ -54,6 +57,8 @@ function MapVeto:createHeader()
return self
end
+---@param firstVeto number?
+---@return self
function MapVeto:vetoStart(firstVeto)
local textLeft
local textCenter
@@ -72,6 +77,8 @@ function MapVeto:vetoStart(firstVeto)
return self
end
+---@param map string?
+---@return string
function MapVeto._displayMap(map)
if Logic.isEmpty(map) then
map = TBD
@@ -82,6 +89,8 @@ function MapVeto._displayMap(map)
return map
end
+---@param map string?
+---@return self
function MapVeto:addDecider(map)
map = MapVeto._displayMap(map)
local row = mw.html.create('tr'):addClass('brkts-popup-mapveto-vetoround')
@@ -94,6 +103,10 @@ function MapVeto:addDecider(map)
return self
end
+---@param vetotype string?
+---@param map1 string?
+---@param map2 string?
+---@return self
function MapVeto:addRound(vetotype, map1, map2)
map1 = MapVeto._displayMap(map1)
map2 = MapVeto._displayMap(map2)
@@ -123,6 +136,10 @@ function MapVeto:addRound(vetotype, map1, map2)
return self
end
+---@param row Html
+---@param styleClass string
+---@param vetoText string
+---@return self
function MapVeto:addColumnVetoType(row, styleClass, vetoText)
row:tag('td')
:tag('span')
@@ -132,79 +149,37 @@ function MapVeto:addColumnVetoType(row, styleClass, vetoText)
return self
end
+---@param row Html
+---@param map string
+---@return self
function MapVeto:addColumnVetoMap(row, map)
row:tag('td'):wikitext(map):done()
return self
end
+---@return Html
function MapVeto:create()
return self.root
end
-
+---@param args table
+---@return Html
function CustomMatchSummary.getByMatchId(args)
- local match = MatchGroupUtil.fetchMatchForBracketDisplay(args.bracketId, args.matchId)
-
- local matchSummary = MatchSummary():init('490px')
- matchSummary:header(CustomMatchSummary._createHeader(match))
- :body(CustomMatchSummary._createBody(match))
-
- if match.comment then
- local comment = MatchSummary.Comment():content(match.comment)
- matchSummary:comment(comment)
- end
-
- local vods = {}
- for index, game in ipairs(match.games) do
- if not Logic.isEmpty(game.vod) then
- vods[index] = game.vod
- end
- end
- match.links.vod = match.vod
-
- if not Table.isEmpty(vods) or not Table.isEmpty(match.links) then
- local footer = MatchSummary.Footer()
-
- -- Match Vod + other links
- local buildLink = function (link, icon, text)
- return '[['..icon..'|link='..link..'|15px|'..text..']]'
- end
-
- for linkType, link in pairs(match.links) do
- if not LINK_DATA[linkType] then
- mw.log('Unknown link: ' .. linkType)
- else
- footer:addElement(buildLink(link, LINK_DATA[linkType].icon, LINK_DATA[linkType].text))
- end
- end
-
- -- Game Vods
- for index, vod in pairs(vods) do
- footer:addElement(VodLink.display{
- gamenum = index,
- vod = vod,
- source = vod.url
- })
- end
-
- matchSummary:footer(footer)
- end
-
- return matchSummary:create()
+ return MatchSummary.defaultGetByMatchId(CustomMatchSummary, args, {width = '490px'})
end
-function CustomMatchSummary._createHeader(match)
- local header = MatchSummary.Header()
-
- header:leftOpponent(header:createOpponent(match.opponents[1], 'left', 'bracket'))
- :leftScore(header:createScore(match.opponents[1]))
- :rightScore(header:createScore(match.opponents[2]))
- :rightOpponent(header:createOpponent(match.opponents[2], 'right', 'bracket'))
+---@param match MatchGroupUtilMatch
+---@param footer MatchSummaryFooter
+---@return MatchSummaryFooter
+function CustomMatchSummary.addToFooter(match, footer)
+ footer = MatchSummary.addVodsToFooter(match, footer)
- return header
+ return footer:addLinks(LINK_DATA, match.links)
end
-function CustomMatchSummary._createBody(match)
+---@param match MatchGroupUtilMatch
+---@return MatchSummaryBody
+function CustomMatchSummary.createBody(match)
local body = MatchSummary.Body()
if match.dateIsExact or match.timestamp ~= DateExt.epochZero then
@@ -260,7 +235,9 @@ function CustomMatchSummary._createBody(match)
return body
end
-function CustomMatchSummary._createGame(game, gameIndex)
+---@param game MatchGroupUtilGame
+---@return MatchSummaryRow
+function CustomMatchSummary._createGame(game)
local row = MatchSummary.Row()
if Logic.isNotEmpty(game.header) then
@@ -329,6 +306,8 @@ function CustomMatchSummary._createGame(game, gameIndex)
return row
end
+---@param game MatchGroupUtilGame
+---@return string
function CustomMatchSummary._getMapDisplay(game)
local mapDisplay = '[[' .. game.map .. ']]'
@@ -339,6 +318,10 @@ function CustomMatchSummary._getMapDisplay(game)
return mapDisplay
end
+---@param game MatchGroupUtilGame
+---@param opponentIndex integer
+---@param flip boolean?
+---@return Html
function CustomMatchSummary._gameScore(game, opponentIndex, flip)
return mw.html.create('div')
:addClass('brkts-popup-body-element-vertical-centered')
@@ -349,6 +332,8 @@ function CustomMatchSummary._gameScore(game, opponentIndex, flip)
)
end
+---@param showIcon boolean?
+---@return Html
function CustomMatchSummary._createCheckMark(showIcon)
local container = mw.html.create('div')
:addClass('brkts-popup-body-element-vertical-centered')
@@ -364,6 +349,8 @@ function CustomMatchSummary._createCheckMark(showIcon)
return container
end
+---@param props {data: string[], flip: boolean, game: string}
+---@return Html
function CustomMatchSummary._opponentWeaponsDisplay(props)
local flip = props.flip