Index: binaries/data/mods/public/gui/summary/summary.js =================================================================== --- binaries/data/mods/public/gui/summary/summary.js +++ binaries/data/mods/public/gui/summary/summary.js @@ -154,6 +154,9 @@ initTeamData(); calculateTeamCounterDataHelper(); + Engine.GetGUIObjectByName("toggleTeamBox").checked = g_Teams && + data && data.selectedData && data.selectedData.teamCharts; + // Output globals initGUIWindow(); initPlayerBoxPositions(); @@ -216,13 +219,13 @@ g_SelectedPanel = panel.name; } -function initGUICharts() +function updateChartColorAndLegend() { - let player_colors = []; + let playerColors = []; for (let i = 1; i <= g_PlayerCount; ++i) { let playerState = g_GameData.sim.playerStates[i]; - player_colors.push( + playerColors.push( Math.floor(playerState.color.r * 255) + " " + Math.floor(playerState.color.g * 255) + " " + Math.floor(playerState.color.b * 255) @@ -230,13 +233,26 @@ } for (let i = 0; i < 2; ++i) - Engine.GetGUIObjectByName("chart[" + i + "]").series_color = player_colors; + Engine.GetGUIObjectByName("chart[" + i + "]").series_color = + Engine.GetGUIObjectByName("toggleTeamBox").checked ? + g_Teams.filter(el => el !== null).map(players => playerColors[players[0] - 1]) : + playerColors; let chartLegend = Engine.GetGUIObjectByName("chartLegend"); - chartLegend.caption = g_GameData.sim.playerStates.slice(1).map( - (state, index) => coloredText("■", player_colors[index]) + " " + state.name - ).join(" "); + chartLegend.caption = Engine.GetGUIObjectByName("toggleTeamBox").checked ? + g_Teams.filter(el => el !== null).map( + players => coloredText("■", playerColors[players[0] - 1]) + " " + players.map(player => + g_GameData.sim.playerStates[player].name + ).join(translateWithContext("Player listing", ", ")) + ).join(" ") : + g_GameData.sim.playerStates.slice(1).map( + (state, index) => coloredText("■", playerColors[index]) + " " + state.name + ).join(" "); +} +function initGUICharts() +{ + updateChartColorAndLegend(); let chart1Part = Engine.GetGUIObjectByName("chart[1]Part"); let chart1PartSize = chart1Part.size; chart1PartSize.rright += 50; @@ -244,6 +260,7 @@ chart1PartSize.right -= 5; chart1PartSize.left -= 5; chart1Part.size = chart1PartSize; + Engine.GetGUIObjectByName("toggleTeam").hidden = !g_Teams; } function resizeDropdown(dropdown) @@ -333,20 +350,37 @@ let chart = Engine.GetGUIObjectByName("chart[" + number + "]"); chart.format_y = g_ScorePanelsData[category].headings[itemNumber + 1].format || "INTEGER"; Engine.GetGUIObjectByName("chart[" + number + "]XAxisLabel").caption = translate("Time elapsed"); + let series = []; - for (let j = 1; j <= g_PlayerCount; ++j) - { - let playerState = g_GameData.sim.playerStates[j]; - let data = []; - for (let index in playerState.sequences.time) + if (Engine.GetGUIObjectByName("toggleTeamBox").checked) + for (let team in g_Teams) { - let value = g_ScorePanelsData[category].counters[itemNumber].fn(playerState, index, item); - if (type) - value = value[type]; - data.push([playerState.sequences.time[index], value]); + let data = []; + for (let index in g_GameData.sim.playerStates[1].sequences.time) + { + let value = g_ScorePanelsData[category].teamCounterFn(team, index, item, + g_ScorePanelsData[category].counters, g_ScorePanelsData[category].headings); + if (type) + value = value[type]; + data.push([g_GameData.sim.playerStates[1].sequences.time[index], value]); + } + series.push(data); } - series.push(data); - } + else + for (let j = 1; j <= g_PlayerCount; ++j) + { + let playerState = g_GameData.sim.playerStates[j]; + let data = []; + for (let index in playerState.sequences.time) + { + let value = g_ScorePanelsData[category].counters[itemNumber].fn(playerState, index, item); + if (type) + value = value[type]; + data.push([playerState.sequences.time[index], value]); + } + series.push(data); + } + chart.series = series; } @@ -440,7 +474,8 @@ { let summarySelectedData = { "panel": g_SelectedPanel, - "charts": g_SelectedChart + "charts": g_SelectedChart, + "teamCharts": Engine.GetGUIObjectByName("toggleTeamBox").checked }; if (g_GameData.gui.isInGame) Engine.PopGuiPageCB({ Index: binaries/data/mods/public/gui/summary/summary.xml =================================================================== --- binaries/data/mods/public/gui/summary/summary.xml +++ binaries/data/mods/public/gui/summary/summary.xml @@ -207,6 +207,19 @@ + + + + + updateChartColorAndLegend(); + updateCategoryDropdown(0); + updateCategoryDropdown(1); + + + + Group by team + +