From d260b612f68ccda499a6fb909d124f92a91fe961 Mon Sep 17 00:00:00 2001 From: Rob Bos Date: Mon, 15 Jan 2024 20:36:57 +0100 Subject: [PATCH] Fix issue on opening of the chart config panel. Fixes #27 (#47) --- vss-extension-dev.json | 2 +- vss-extension.json | 2 +- widgets/widgets/chart/configuration_2x2.html | 64 ++++++++++---------- 3 files changed, 33 insertions(+), 35 deletions(-) diff --git a/vss-extension-dev.json b/vss-extension-dev.json index 665ac4a..76f09d2 100644 --- a/vss-extension-dev.json +++ b/vss-extension-dev.json @@ -1,7 +1,7 @@ { "manifestVersion": 1, "id": "GHAzDoWidget-DEV", - "version": "0.2.427", + "version": "0.2.432", "public": false, "name": "Advanced Security dashboard Widgets [DEV]", "description": "[DEV] GitHub Advanced Security for Azure DevOps dashboard widgets", diff --git a/vss-extension.json b/vss-extension.json index 9d8d18a..b4d1f81 100644 --- a/vss-extension.json +++ b/vss-extension.json @@ -1,7 +1,7 @@ { "manifestVersion": 1, "id": "GHAzDoWidget", - "version": "0.0.1.20", + "version": "0.0.1.21", "public": true, "name": "Advanced Security dashboard Widgets", "description": "GitHub Advanced Security for Azure DevOps dashboard widgets", diff --git a/widgets/widgets/chart/configuration_2x2.html b/widgets/widgets/chart/configuration_2x2.html index d2abcf9..c603901 100644 --- a/widgets/widgets/chart/configuration_2x2.html +++ b/widgets/widgets/chart/configuration_2x2.html @@ -17,7 +17,6 @@ const $repoDropdown = $("#repo-dropdown"); const $chartTypeDropdown = $("#chart-type"); const $alertTypeDropdown = $("#alert-type"); - const repos = await getRepos(VSS, Service, GitWebApi); function reloadWidget(widgetConfigurationContext) { const customSettings = getSettings(); @@ -27,28 +26,21 @@ } function getSettings() { - if (repos) { - // find the repo with this name - const repo = repos.find(r => r.name === $repoDropdown.val()); - - if (repo) { - var customSettings = { - data: JSON.stringify({ - repo: $repoDropdown.val(), - repoId: repo.id, - chartType: $chartTypeDropdown.val(), - alertType: $alertTypeDropdown.val() - }) - }; - return customSettings; - } - } - return {}; + var customSettings = { + data: JSON.stringify({ + repo: getSelectedRepoNameFromDropdown($repoDropdown), + repoId: getSelectedRepoIdFromDropdown($repoDropdown), + chartType: $chartTypeDropdown.val(), + alertType: $alertTypeDropdown.val() + }) + }; + return customSettings; } function reloadChartOptions() { const chartType = $chartTypeDropdown.val(); + console.log(`Inside reloadChartOptions with chartType [${chartType}]`); if (chartType === "1") { // trend line $("#alertTypePanel").hide(); @@ -57,39 +49,36 @@ // pie chart $("#alertTypePanel").show(); } + else if (chartType === "3") { + // pie chart + $("#alertTypePanel").show(); + } } return { load: async function (widgetSettings, widgetConfigurationContext) { var settings = logWidgetSettings(widgetSettings, VSS, "Chart.2x2"); - - // add all repos as selection options to the dropdown + const repos = await getRepos(VSS, Service, GitWebApi); if (repos) { - // add a top option to select no repo - $repoDropdown.append(``); - // sort the repo alphabetically - repos.sort((a, b) => a.name.localeCompare(b.name)); - repos.forEach(r => { - $repoDropdown.append(``); - }); + fillSelectRepoDropdown($repoDropdown, repos); } - if (settings && settings.repo) { + if (settings && settings.repoId) { // select the repo that was saved in the settings - $repoDropdown.val(settings.repo); - } + $repoDropdown.val(settings.repoId); + } - if (settings && settings.chartType) { + if (settings && settings.chartType) { // select the chartType that was saved in the settings $chartTypeDropdown.val(settings.chartType); - } + } if (settings && settings.alertType) { // select the alertType that was saved in the settings $alertTypeDropdown.val(settings.alertType); } - // register a change event handler for the dropdowns + // register a change event handler for the dropdowns $repoDropdown.on("change", function () { reloadWidget(widgetConfigurationContext) }); @@ -99,6 +88,9 @@ reloadChartOptions(); }); + // call the chartTypeDrowdown change handler to show/hide the alertType dropdown + reloadChartOptions(); + $alertTypeDropdown.on("change", function () { reloadWidget(widgetConfigurationContext) }); @@ -107,6 +99,12 @@ }, onSave: async function() { const customSettings = getSettings(); + let repoId = getSelectedRepoIdFromDropdown($repoDropdown); + if (repoId == 0 || repoId == 1) { // 0 = select a repo, 1 = all repos + // do not save + console.log(`Not saving the settings because repoId is [${repoId}]`); + return WidgetHelpers.WidgetConfigurationSave.Invalid(); + } console.log(`Saving the Chart.2x2 settings with ${JSON.stringify(customSettings)}`) return WidgetHelpers.WidgetConfigurationSave.Valid(customSettings);