@backstage-community/plugin-apiiro 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +12 -0
- package/README.md +232 -0
- package/config.d.ts +30 -0
- package/dist/App.esm.js +12 -0
- package/dist/App.esm.js.map +1 -0
- package/dist/api/index.esm.js +71 -0
- package/dist/api/index.esm.js.map +1 -0
- package/dist/assets/BulleyeIcon.esm.js +454 -0
- package/dist/assets/BulleyeIcon.esm.js.map +1 -0
- package/dist/assets/NoResultIcon.esm.js +146 -0
- package/dist/assets/NoResultIcon.esm.js.map +1 -0
- package/dist/assets/RiskIcon.esm.js +27 -0
- package/dist/assets/RiskIcon.esm.js.map +1 -0
- package/dist/assets/SettingIcon.esm.js +49 -0
- package/dist/assets/SettingIcon.esm.js.map +1 -0
- package/dist/assets/apiiroLogo/apiiroLogo.esm.js +21 -0
- package/dist/assets/apiiroLogo/apiiroLogo.esm.js.map +1 -0
- package/dist/assets/apiiroLogo/apiiroSidebar.esm.js +23 -0
- package/dist/assets/apiiroLogo/apiiroSidebar.esm.js.map +1 -0
- package/dist/assets/apiiroLogo/apiiroSmall.esm.js +19 -0
- package/dist/assets/apiiroLogo/apiiroSmall.esm.js.map +1 -0
- package/dist/assets/languageIcons/C.esm.js +7 -0
- package/dist/assets/languageIcons/C.esm.js.map +1 -0
- package/dist/assets/languageIcons/Cicd.esm.js +7 -0
- package/dist/assets/languageIcons/Cicd.esm.js.map +1 -0
- package/dist/assets/languageIcons/Clojure.esm.js +7 -0
- package/dist/assets/languageIcons/Clojure.esm.js.map +1 -0
- package/dist/assets/languageIcons/Cpp.esm.js +7 -0
- package/dist/assets/languageIcons/Cpp.esm.js.map +1 -0
- package/dist/assets/languageIcons/Csharp.esm.js +7 -0
- package/dist/assets/languageIcons/Csharp.esm.js.map +1 -0
- package/dist/assets/languageIcons/Dart.esm.js +7 -0
- package/dist/assets/languageIcons/Dart.esm.js.map +1 -0
- package/dist/assets/languageIcons/Go.esm.js +7 -0
- package/dist/assets/languageIcons/Go.esm.js.map +1 -0
- package/dist/assets/languageIcons/Groovy.esm.js +7 -0
- package/dist/assets/languageIcons/Groovy.esm.js.map +1 -0
- package/dist/assets/languageIcons/HTML.esm.js +7 -0
- package/dist/assets/languageIcons/HTML.esm.js.map +1 -0
- package/dist/assets/languageIcons/HclLanguage.esm.js +7 -0
- package/dist/assets/languageIcons/HclLanguage.esm.js.map +1 -0
- package/dist/assets/languageIcons/Java.esm.js +7 -0
- package/dist/assets/languageIcons/Java.esm.js.map +1 -0
- package/dist/assets/languageIcons/Javascript.esm.js +7 -0
- package/dist/assets/languageIcons/Javascript.esm.js.map +1 -0
- package/dist/assets/languageIcons/Kotlin.esm.js +7 -0
- package/dist/assets/languageIcons/Kotlin.esm.js.map +1 -0
- package/dist/assets/languageIcons/ObjectiveC.esm.js +7 -0
- package/dist/assets/languageIcons/ObjectiveC.esm.js.map +1 -0
- package/dist/assets/languageIcons/PHP.esm.js +7 -0
- package/dist/assets/languageIcons/PHP.esm.js.map +1 -0
- package/dist/assets/languageIcons/Perl.esm.js +13 -0
- package/dist/assets/languageIcons/Perl.esm.js.map +1 -0
- package/dist/assets/languageIcons/Python.esm.js +7 -0
- package/dist/assets/languageIcons/Python.esm.js.map +1 -0
- package/dist/assets/languageIcons/Ruby.esm.js +7 -0
- package/dist/assets/languageIcons/Ruby.esm.js.map +1 -0
- package/dist/assets/languageIcons/Rust.esm.js +7 -0
- package/dist/assets/languageIcons/Rust.esm.js.map +1 -0
- package/dist/assets/languageIcons/Scala.esm.js +7 -0
- package/dist/assets/languageIcons/Scala.esm.js.map +1 -0
- package/dist/assets/languageIcons/Swift.esm.js +7 -0
- package/dist/assets/languageIcons/Swift.esm.js.map +1 -0
- package/dist/assets/languageIcons/Terraform.esm.js +7 -0
- package/dist/assets/languageIcons/Terraform.esm.js.map +1 -0
- package/dist/assets/languageIcons/Typescript.esm.js +7 -0
- package/dist/assets/languageIcons/Typescript.esm.js.map +1 -0
- package/dist/assets/languageIcons/Unknown.esm.js +7 -0
- package/dist/assets/languageIcons/Unknown.esm.js.map +1 -0
- package/dist/assets/languageIcons/VB.esm.js +10 -0
- package/dist/assets/languageIcons/VB.esm.js.map +1 -0
- package/dist/assets/languageIcons/YAML.esm.js +7 -0
- package/dist/assets/languageIcons/YAML.esm.js.map +1 -0
- package/dist/assets/providerIcons/Azure.esm.js +7 -0
- package/dist/assets/providerIcons/Azure.esm.js.map +1 -0
- package/dist/assets/providerIcons/Bitbucket.esm.js +7 -0
- package/dist/assets/providerIcons/Bitbucket.esm.js.map +1 -0
- package/dist/assets/providerIcons/Gitlab.esm.js +7 -0
- package/dist/assets/providerIcons/Gitlab.esm.js.map +1 -0
- package/dist/components/ApiiroSidebar.esm.js +10 -0
- package/dist/components/ApiiroSidebar.esm.js.map +1 -0
- package/dist/components/ApplicationsList/ApplicationsList.esm.js +196 -0
- package/dist/components/ApplicationsList/ApplicationsList.esm.js.map +1 -0
- package/dist/components/CalendarDatePicker.esm.js +154 -0
- package/dist/components/CalendarDatePicker.esm.js.map +1 -0
- package/dist/components/CalendarDatePicker.styles.esm.js +198 -0
- package/dist/components/CalendarDatePicker.styles.esm.js.map +1 -0
- package/dist/components/Chip.esm.js +60 -0
- package/dist/components/Chip.esm.js.map +1 -0
- package/dist/components/ChipsList.esm.js +207 -0
- package/dist/components/ChipsList.esm.js.map +1 -0
- package/dist/components/ComponentDisplay.esm.js +42 -0
- package/dist/components/ComponentDisplay.esm.js.map +1 -0
- package/dist/components/DataGrid/CustomColumnMenu.esm.js +29 -0
- package/dist/components/DataGrid/CustomColumnMenu.esm.js.map +1 -0
- package/dist/components/DataGrid/CustomPagination.esm.js +113 -0
- package/dist/components/DataGrid/CustomPagination.esm.js.map +1 -0
- package/dist/components/DataGrid/CustomSearchToolbar.esm.js +117 -0
- package/dist/components/DataGrid/CustomSearchToolbar.esm.js.map +1 -0
- package/dist/components/DataGrid/DataGrid.esm.js +336 -0
- package/dist/components/DataGrid/DataGrid.esm.js.map +1 -0
- package/dist/components/DataGrid/PinColumnMenuItem.esm.js +24 -0
- package/dist/components/DataGrid/PinColumnMenuItem.esm.js.map +1 -0
- package/dist/components/DueDate.esm.js +34 -0
- package/dist/components/DueDate.esm.js.map +1 -0
- package/dist/components/Header.esm.js +27 -0
- package/dist/components/Header.esm.js.map +1 -0
- package/dist/components/MainContributors/MainContributors.esm.js +62 -0
- package/dist/components/MainContributors/MainContributors.esm.js.map +1 -0
- package/dist/components/MetricsGroup/TabMetricsGroup.esm.js +37 -0
- package/dist/components/MetricsGroup/TabMetricsGroup.esm.js.map +1 -0
- package/dist/components/MetricsGroup/WidgetMetricsGroup.esm.js +36 -0
- package/dist/components/MetricsGroup/WidgetMetricsGroup.esm.js.map +1 -0
- package/dist/components/RepositoryDisplay/RepositoryDisplay.esm.js +121 -0
- package/dist/components/RepositoryDisplay/RepositoryDisplay.esm.js.map +1 -0
- package/dist/components/RiskLevel.esm.js +88 -0
- package/dist/components/RiskLevel.esm.js.map +1 -0
- package/dist/components/RiskStatus.esm.js +58 -0
- package/dist/components/RiskStatus.esm.js.map +1 -0
- package/dist/components/SimpleTooltip.esm.js +24 -0
- package/dist/components/SimpleTooltip.esm.js.map +1 -0
- package/dist/components/SourcesDisplay.esm.js +47 -0
- package/dist/components/SourcesDisplay.esm.js.map +1 -0
- package/dist/components/TagsList/TagsList.esm.js +38 -0
- package/dist/components/TagsList/TagsList.esm.js.map +1 -0
- package/dist/components/TeamsDisplay.esm.js +47 -0
- package/dist/components/TeamsDisplay.esm.js.map +1 -0
- package/dist/components/charts/ColumnChart.esm.js +402 -0
- package/dist/components/charts/ColumnChart.esm.js.map +1 -0
- package/dist/components/charts/GaugeChart.esm.js +249 -0
- package/dist/components/charts/GaugeChart.esm.js.map +1 -0
- package/dist/components/charts/LineChart.esm.js +328 -0
- package/dist/components/charts/LineChart.esm.js.map +1 -0
- package/dist/components/charts/PieChart.esm.js +233 -0
- package/dist/components/charts/PieChart.esm.js.map +1 -0
- package/dist/components/common/ChartBox.esm.js +88 -0
- package/dist/components/common/ChartBox.esm.js.map +1 -0
- package/dist/components/common/CustomTooltip.esm.js +255 -0
- package/dist/components/common/CustomTooltip.esm.js.map +1 -0
- package/dist/components/common/ErrorSnackbar.esm.js +39 -0
- package/dist/components/common/ErrorSnackbar.esm.js.map +1 -0
- package/dist/components/common/NotFound.esm.js +30 -0
- package/dist/components/common/NotFound.esm.js.map +1 -0
- package/dist/components/common/SomethingWentWrong.esm.js +35 -0
- package/dist/components/common/SomethingWentWrong.esm.js.map +1 -0
- package/dist/components/common/languageIcons.esm.js +61 -0
- package/dist/components/common/languageIcons.esm.js.map +1 -0
- package/dist/components/common/logoSpinner.esm.js +28 -0
- package/dist/components/common/logoSpinner.esm.js.map +1 -0
- package/dist/components/common/scmProviders.esm.js +41 -0
- package/dist/components/common/scmProviders.esm.js.map +1 -0
- package/dist/components/filters/DiscoveredOnFilter.esm.js +284 -0
- package/dist/components/filters/DiscoveredOnFilter.esm.js.map +1 -0
- package/dist/components/filters/FilterDropdown.esm.js +325 -0
- package/dist/components/filters/FilterDropdown.esm.js.map +1 -0
- package/dist/components/filters/FilterDropdownClear.esm.js +45 -0
- package/dist/components/filters/FilterDropdownClear.esm.js.map +1 -0
- package/dist/components/filters/FilterDropdownList.esm.js +102 -0
- package/dist/components/filters/FilterDropdownList.esm.js.map +1 -0
- package/dist/components/filters/FilterDropdownSearch.esm.js +65 -0
- package/dist/components/filters/FilterDropdownSearch.esm.js.map +1 -0
- package/dist/components/filters/RiskInsightFilter.esm.js +579 -0
- package/dist/components/filters/RiskInsightFilter.esm.js.map +1 -0
- package/dist/components/tiles/MttrVsSLATile.esm.js +170 -0
- package/dist/components/tiles/MttrVsSLATile.esm.js.map +1 -0
- package/dist/components/tiles/RiskOverTimeTile.esm.js +311 -0
- package/dist/components/tiles/RiskOverTimeTile.esm.js.map +1 -0
- package/dist/components/tiles/SLAAdherenceTile.esm.js +115 -0
- package/dist/components/tiles/SLAAdherenceTile.esm.js.map +1 -0
- package/dist/components/tiles/StatusTile.esm.js +235 -0
- package/dist/components/tiles/StatusTile.esm.js.map +1 -0
- package/dist/components/tiles/TopLanguagesTile.esm.js +234 -0
- package/dist/components/tiles/TopLanguagesTile.esm.js.map +1 -0
- package/dist/components/tiles/TopRiskTile.esm.js +208 -0
- package/dist/components/tiles/TopRiskTile.esm.js.map +1 -0
- package/dist/hooks/useUrlFilters.esm.js +102 -0
- package/dist/hooks/useUrlFilters.esm.js.map +1 -0
- package/dist/index.d.ts +28 -0
- package/dist/index.esm.js +42 -0
- package/dist/index.esm.js.map +1 -0
- package/dist/pages/Repositories/Repositories.esm.js +102 -0
- package/dist/pages/Repositories/Repositories.esm.js.map +1 -0
- package/dist/pages/Repositories/tableConfig.esm.js +294 -0
- package/dist/pages/Repositories/tableConfig.esm.js.map +1 -0
- package/dist/pages/Risks/Risks.esm.js +258 -0
- package/dist/pages/Risks/Risks.esm.js.map +1 -0
- package/dist/pages/Risks/tableConfig.esm.js +305 -0
- package/dist/pages/Risks/tableConfig.esm.js.map +1 -0
- package/dist/pages/tab/Tab.esm.js +147 -0
- package/dist/pages/tab/Tab.esm.js.map +1 -0
- package/dist/pages/tab/TabProvider.esm.js +11 -0
- package/dist/pages/tab/TabProvider.esm.js.map +1 -0
- package/dist/pages/widget/Widget.esm.js +161 -0
- package/dist/pages/widget/Widget.esm.js.map +1 -0
- package/dist/pages/widget/WidgetProvider.esm.js +12 -0
- package/dist/pages/widget/WidgetProvider.esm.js.map +1 -0
- package/dist/plugin.esm.js +30 -0
- package/dist/plugin.esm.js.map +1 -0
- package/dist/queries/filterOptions.queries.esm.js +46 -0
- package/dist/queries/filterOptions.queries.esm.js.map +1 -0
- package/dist/queries/mttr-statistics.queries.esm.js +61 -0
- package/dist/queries/mttr-statistics.queries.esm.js.map +1 -0
- package/dist/queries/repository.queries.esm.js +60 -0
- package/dist/queries/repository.queries.esm.js.map +1 -0
- package/dist/queries/risk-score-over-time.queries.esm.js +61 -0
- package/dist/queries/risk-score-over-time.queries.esm.js.map +1 -0
- package/dist/queries/risks.queries.esm.js +65 -0
- package/dist/queries/risks.queries.esm.js.map +1 -0
- package/dist/queries/sla-breach.queries.esm.js +57 -0
- package/dist/queries/sla-breach.queries.esm.js.map +1 -0
- package/dist/queries/top-risks.queries.esm.js +47 -0
- package/dist/queries/top-risks.queries.esm.js.map +1 -0
- package/dist/routes.esm.js +8 -0
- package/dist/routes.esm.js.map +1 -0
- package/dist/theme/themeUtils.esm.js +290 -0
- package/dist/theme/themeUtils.esm.js.map +1 -0
- package/dist/utils/dateFormatter.esm.js +67 -0
- package/dist/utils/dateFormatter.esm.js.map +1 -0
- package/dist/utils/numberFormatter.esm.js +21 -0
- package/dist/utils/numberFormatter.esm.js.map +1 -0
- package/dist/utils/utils.esm.js +27 -0
- package/dist/utils/utils.esm.js.map +1 -0
- package/package.json +90 -0
|
@@ -0,0 +1,294 @@
|
|
|
1
|
+
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
2
|
+
import { Link } from 'react-router-dom';
|
|
3
|
+
import '@backstage/core-components';
|
|
4
|
+
import '@mui/material/SvgIcon';
|
|
5
|
+
import 'react';
|
|
6
|
+
import '@mui/x-data-grid';
|
|
7
|
+
import Box from '@mui/material/Box';
|
|
8
|
+
import '@mui/material/styles';
|
|
9
|
+
import '@mui/material/MenuItem';
|
|
10
|
+
import '@mui/material/ListItemIcon';
|
|
11
|
+
import '@mui/material/ListItemText';
|
|
12
|
+
import '@mui/icons-material';
|
|
13
|
+
import Typography from '@mui/material/Typography';
|
|
14
|
+
import '@mui/material/Select';
|
|
15
|
+
import '@mui/material/Pagination';
|
|
16
|
+
import '@mui/material/TextField';
|
|
17
|
+
import '@mui/material/InputAdornment';
|
|
18
|
+
import '@mui/icons-material/Search';
|
|
19
|
+
import '@mui/icons-material/Clear';
|
|
20
|
+
import '@mui/material/IconButton';
|
|
21
|
+
import '../../components/common/ChartBox.esm.js';
|
|
22
|
+
import 'react-dom';
|
|
23
|
+
import '../../components/common/logoSpinner.esm.js';
|
|
24
|
+
import { Chip } from '../../components/Chip.esm.js';
|
|
25
|
+
import { ChipsList } from '../../components/ChipsList.esm.js';
|
|
26
|
+
import { RiskLevel } from '../../components/RiskLevel.esm.js';
|
|
27
|
+
import { SimpleTooltip } from '../../components/SimpleTooltip.esm.js';
|
|
28
|
+
import '@mui/material/Avatar';
|
|
29
|
+
import '@mui/material/Chip';
|
|
30
|
+
import '@mui/material/Link';
|
|
31
|
+
import 'react-icons/vsc';
|
|
32
|
+
import 'react-icons/si';
|
|
33
|
+
import '@backstage-community/plugin-apiiro-common';
|
|
34
|
+
import { formatDate } from '../../utils/dateFormatter.esm.js';
|
|
35
|
+
import '../../components/filters/FilterDropdown.esm.js';
|
|
36
|
+
import '../../components/filters/RiskInsightFilter.esm.js';
|
|
37
|
+
import '../../components/CalendarDatePicker.esm.js';
|
|
38
|
+
import '@mui/material/ButtonBase';
|
|
39
|
+
import '@mui/material/Popper';
|
|
40
|
+
import '@mui/material/ClickAwayListener';
|
|
41
|
+
import '@mui/material/Tooltip';
|
|
42
|
+
import '@mui/material/Skeleton';
|
|
43
|
+
import '@mui/icons-material/KeyboardArrowDown';
|
|
44
|
+
import '@mui/icons-material/Close';
|
|
45
|
+
import { scmProviderIcons } from '../../components/common/scmProviders.esm.js';
|
|
46
|
+
|
|
47
|
+
const businessImpactColorMapping = {
|
|
48
|
+
High: "error",
|
|
49
|
+
Medium: "warning",
|
|
50
|
+
Low: "warning"
|
|
51
|
+
};
|
|
52
|
+
const repositoryColumns = [
|
|
53
|
+
{
|
|
54
|
+
field: "name",
|
|
55
|
+
headerName: "Repository Name",
|
|
56
|
+
flex: 1.5,
|
|
57
|
+
hideable: false,
|
|
58
|
+
minWidth: 230,
|
|
59
|
+
valueGetter: (_, row) => `${row.name} (${row.branchName})`,
|
|
60
|
+
renderCell: (params) => {
|
|
61
|
+
const IconComponent = scmProviderIcons[params.row.provider];
|
|
62
|
+
const redirectURL = `${params.row.entityUrl}/apiiro`;
|
|
63
|
+
return /* @__PURE__ */ jsx(SimpleTooltip, { title: params.formattedValue || "", children: /* @__PURE__ */ jsxs(
|
|
64
|
+
"div",
|
|
65
|
+
{
|
|
66
|
+
style: {
|
|
67
|
+
display: "flex",
|
|
68
|
+
alignItems: "center",
|
|
69
|
+
gap: "5px",
|
|
70
|
+
width: "100%",
|
|
71
|
+
minWidth: 0
|
|
72
|
+
},
|
|
73
|
+
children: [
|
|
74
|
+
IconComponent && /* @__PURE__ */ jsx(IconComponent, { style: { flexShrink: 0 } }),
|
|
75
|
+
/* @__PURE__ */ jsx(
|
|
76
|
+
Link,
|
|
77
|
+
{
|
|
78
|
+
to: redirectURL,
|
|
79
|
+
style: {
|
|
80
|
+
overflow: "hidden",
|
|
81
|
+
textOverflow: "ellipsis",
|
|
82
|
+
whiteSpace: "nowrap",
|
|
83
|
+
minWidth: 0,
|
|
84
|
+
flex: 1
|
|
85
|
+
},
|
|
86
|
+
children: params.formattedValue
|
|
87
|
+
}
|
|
88
|
+
)
|
|
89
|
+
]
|
|
90
|
+
}
|
|
91
|
+
) });
|
|
92
|
+
}
|
|
93
|
+
},
|
|
94
|
+
{
|
|
95
|
+
field: "visibility",
|
|
96
|
+
headerName: "Public/Private",
|
|
97
|
+
flex: 1.2,
|
|
98
|
+
minWidth: 150,
|
|
99
|
+
headerAlign: "center",
|
|
100
|
+
valueGetter: (_, row) => row.isPublic ? "Public" : "Private",
|
|
101
|
+
renderCell: (params) => /* @__PURE__ */ jsx(
|
|
102
|
+
SimpleTooltip,
|
|
103
|
+
{
|
|
104
|
+
title: params.formattedValue || "",
|
|
105
|
+
centered: true,
|
|
106
|
+
tooltipProps: {
|
|
107
|
+
PopperProps: {
|
|
108
|
+
modifiers: [{ name: "offset", options: { offset: [0, -20] } }]
|
|
109
|
+
}
|
|
110
|
+
},
|
|
111
|
+
children: params.formattedValue
|
|
112
|
+
}
|
|
113
|
+
)
|
|
114
|
+
},
|
|
115
|
+
{
|
|
116
|
+
field: "businessImpact",
|
|
117
|
+
headerName: "Business Impact",
|
|
118
|
+
flex: 1.2,
|
|
119
|
+
minWidth: 150,
|
|
120
|
+
headerAlign: "center",
|
|
121
|
+
renderCell: (params) => /* @__PURE__ */ jsx(SimpleTooltip, { title: params.value ?? "", centered: true, children: /* @__PURE__ */ jsx(
|
|
122
|
+
Chip,
|
|
123
|
+
{
|
|
124
|
+
label: params.value,
|
|
125
|
+
colorMapping: businessImpactColorMapping,
|
|
126
|
+
size: "small",
|
|
127
|
+
variant: "outlined",
|
|
128
|
+
chipSx: { marginBottom: "0" }
|
|
129
|
+
}
|
|
130
|
+
) })
|
|
131
|
+
},
|
|
132
|
+
{
|
|
133
|
+
field: "riskLevel",
|
|
134
|
+
headerName: "Risk Level",
|
|
135
|
+
flex: 1,
|
|
136
|
+
minWidth: 150,
|
|
137
|
+
headerAlign: "center",
|
|
138
|
+
renderCell: (params) => /* @__PURE__ */ jsx(SimpleTooltip, { title: params.value ?? "", centered: true, children: /* @__PURE__ */ jsx(RiskLevel, { level: params.value, iconSize: "large" }) })
|
|
139
|
+
},
|
|
140
|
+
{
|
|
141
|
+
field: "riskScore",
|
|
142
|
+
headerName: "Risk Score",
|
|
143
|
+
flex: 1,
|
|
144
|
+
minWidth: 150,
|
|
145
|
+
headerAlign: "center",
|
|
146
|
+
renderCell: (params) => /* @__PURE__ */ jsx(SimpleTooltip, { title: params.value ?? "", centered: true, children: params.value ?? "" })
|
|
147
|
+
},
|
|
148
|
+
{
|
|
149
|
+
field: "languages",
|
|
150
|
+
headerName: "Languages",
|
|
151
|
+
flex: 1.5,
|
|
152
|
+
minWidth: 200,
|
|
153
|
+
valueGetter: (_, row) => row.languages,
|
|
154
|
+
renderCell: (params) => {
|
|
155
|
+
return /* @__PURE__ */ jsx(
|
|
156
|
+
Box,
|
|
157
|
+
{
|
|
158
|
+
sx: {
|
|
159
|
+
position: "relative",
|
|
160
|
+
display: "flex",
|
|
161
|
+
alignItems: "center",
|
|
162
|
+
justifyContent: "center",
|
|
163
|
+
height: "100%",
|
|
164
|
+
width: "100%"
|
|
165
|
+
},
|
|
166
|
+
children: /* @__PURE__ */ jsx(
|
|
167
|
+
ChipsList,
|
|
168
|
+
{
|
|
169
|
+
items: params.value.map((item) => ({
|
|
170
|
+
id: item,
|
|
171
|
+
label: item
|
|
172
|
+
})),
|
|
173
|
+
maxVisible: 2,
|
|
174
|
+
gap: 0,
|
|
175
|
+
variant: "outlined"
|
|
176
|
+
}
|
|
177
|
+
)
|
|
178
|
+
}
|
|
179
|
+
);
|
|
180
|
+
}
|
|
181
|
+
},
|
|
182
|
+
{
|
|
183
|
+
field: "isDeployed",
|
|
184
|
+
headerName: "Deployed",
|
|
185
|
+
flex: 1,
|
|
186
|
+
minWidth: 150,
|
|
187
|
+
headerAlign: "center",
|
|
188
|
+
valueGetter: (_, row) => row.isDeployed ? "Yes" : "No",
|
|
189
|
+
renderCell: (params) => /* @__PURE__ */ jsx(SimpleTooltip, { title: params.formattedValue || "", centered: true, children: params.formattedValue })
|
|
190
|
+
},
|
|
191
|
+
{
|
|
192
|
+
field: "isInternetExposed",
|
|
193
|
+
headerName: "Internet Exposed",
|
|
194
|
+
flex: 1,
|
|
195
|
+
minWidth: 150,
|
|
196
|
+
headerAlign: "center",
|
|
197
|
+
valueGetter: (_, row) => row.isInternetExposed ? "Yes" : "No",
|
|
198
|
+
renderCell: (params) => /* @__PURE__ */ jsx(SimpleTooltip, { title: params.formattedValue || "", centered: true, children: params.formattedValue })
|
|
199
|
+
},
|
|
200
|
+
{
|
|
201
|
+
field: "apiCount",
|
|
202
|
+
headerName: "APIs",
|
|
203
|
+
flex: 1,
|
|
204
|
+
minWidth: 150,
|
|
205
|
+
headerAlign: "center",
|
|
206
|
+
renderCell: (params) => /* @__PURE__ */ jsx(SimpleTooltip, { title: params.value ?? "", centered: true, children: params.value ?? "" })
|
|
207
|
+
},
|
|
208
|
+
{
|
|
209
|
+
field: "sensitiveData",
|
|
210
|
+
headerName: "Sensitive Data",
|
|
211
|
+
flex: 1.2,
|
|
212
|
+
minWidth: 150,
|
|
213
|
+
headerAlign: "center",
|
|
214
|
+
renderCell: (params) => {
|
|
215
|
+
const sensitiveTypes = [];
|
|
216
|
+
if (params.row.hasPiiData) sensitiveTypes.push("PII");
|
|
217
|
+
if (params.row.hasPhiData) sensitiveTypes.push("PHI");
|
|
218
|
+
if (params.row.hasPaymentsData) sensitiveTypes.push("Payments");
|
|
219
|
+
const displayValue = sensitiveTypes.length > 0 ? "Yes" : "No";
|
|
220
|
+
const tooltipText = sensitiveTypes.length > 0 ? `Contains: ${sensitiveTypes.join(", ")}` : "No sensitive data";
|
|
221
|
+
return /* @__PURE__ */ jsx(SimpleTooltip, { title: tooltipText, centered: true, children: /* @__PURE__ */ jsx(Typography, { children: displayValue }) });
|
|
222
|
+
}
|
|
223
|
+
},
|
|
224
|
+
{
|
|
225
|
+
field: "contributorCount",
|
|
226
|
+
headerName: "Contributors",
|
|
227
|
+
flex: 1,
|
|
228
|
+
minWidth: 150,
|
|
229
|
+
headerAlign: "center",
|
|
230
|
+
renderCell: (params) => /* @__PURE__ */ jsx(SimpleTooltip, { title: params.value ?? "", centered: true, children: params.value ?? "" })
|
|
231
|
+
},
|
|
232
|
+
{
|
|
233
|
+
field: "activeSince",
|
|
234
|
+
headerName: "Active Since",
|
|
235
|
+
type: "date",
|
|
236
|
+
flex: 1.2,
|
|
237
|
+
minWidth: 150,
|
|
238
|
+
headerAlign: "center",
|
|
239
|
+
valueGetter: (_, row) => row.activeSince ? new Date(row.activeSince) : null,
|
|
240
|
+
renderCell: (params) => /* @__PURE__ */ jsx(
|
|
241
|
+
SimpleTooltip,
|
|
242
|
+
{
|
|
243
|
+
title: params.value?.toLocaleDateString() || "N/A",
|
|
244
|
+
centered: true,
|
|
245
|
+
children: params.value ? formatDate(params.value) : "N/A"
|
|
246
|
+
}
|
|
247
|
+
)
|
|
248
|
+
},
|
|
249
|
+
{
|
|
250
|
+
field: "lastActivity",
|
|
251
|
+
headerName: "Last Activity",
|
|
252
|
+
type: "date",
|
|
253
|
+
flex: 1.2,
|
|
254
|
+
minWidth: 150,
|
|
255
|
+
headerAlign: "center",
|
|
256
|
+
valueGetter: (_, row) => row.lastActivity ? new Date(row.lastActivity) : null,
|
|
257
|
+
renderCell: (params) => /* @__PURE__ */ jsx(
|
|
258
|
+
SimpleTooltip,
|
|
259
|
+
{
|
|
260
|
+
title: params.value?.toLocaleDateString() || "N/A",
|
|
261
|
+
centered: true,
|
|
262
|
+
children: params.value ? formatDate(params.value) : "N/A"
|
|
263
|
+
}
|
|
264
|
+
)
|
|
265
|
+
},
|
|
266
|
+
{
|
|
267
|
+
field: "isArchived",
|
|
268
|
+
headerName: "Archived",
|
|
269
|
+
flex: 1,
|
|
270
|
+
minWidth: 150,
|
|
271
|
+
headerAlign: "center",
|
|
272
|
+
valueGetter: (_, row) => row.isArchived ? "Yes" : "No",
|
|
273
|
+
renderCell: (params) => /* @__PURE__ */ jsx(SimpleTooltip, { title: params.formattedValue || "", centered: true, children: params.formattedValue })
|
|
274
|
+
}
|
|
275
|
+
];
|
|
276
|
+
const columnVisibilityModal = {
|
|
277
|
+
name: true,
|
|
278
|
+
visibility: true,
|
|
279
|
+
businessImpact: true,
|
|
280
|
+
riskLevel: true,
|
|
281
|
+
riskScore: true,
|
|
282
|
+
languages: true,
|
|
283
|
+
isDeployed: false,
|
|
284
|
+
isInternetExposed: false,
|
|
285
|
+
apiCount: false,
|
|
286
|
+
sensitiveData: false,
|
|
287
|
+
contributorCount: false,
|
|
288
|
+
activeSince: false,
|
|
289
|
+
lastActivity: false,
|
|
290
|
+
isArchived: false
|
|
291
|
+
};
|
|
292
|
+
|
|
293
|
+
export { businessImpactColorMapping, columnVisibilityModal, repositoryColumns };
|
|
294
|
+
//# sourceMappingURL=tableConfig.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tableConfig.esm.js","sources":["../../../src/pages/Repositories/tableConfig.tsx"],"sourcesContent":["/*\n * Copyright 2025 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { GridColDef } from '@mui/x-data-grid';\nimport { Link } from 'react-router-dom';\nimport { Chip, ChipsList, RiskLevel, SimpleTooltip } from '../../components';\nimport { scmProviderIcons } from '../../components/common/scmProviders';\nimport { formatDate } from '../../utils/dateFormatter';\nimport Typography from '@mui/material/Typography';\nimport Box from '@mui/material/Box';\n\n// Color mapping for business impact\nexport const businessImpactColorMapping = {\n High: 'error',\n Medium: 'warning',\n Low: 'warning',\n} as const;\n\n// Repository columns configuration\nexport const repositoryColumns: GridColDef[] = [\n {\n field: 'name',\n headerName: 'Repository Name',\n flex: 1.5,\n hideable: false,\n minWidth: 230,\n valueGetter: (_, row) => `${row.name} (${row.branchName})`,\n renderCell: (params: any) => {\n const IconComponent = scmProviderIcons[params.row.provider as string];\n const redirectURL = `${params.row.entityUrl}/apiiro`;\n return (\n <SimpleTooltip title={params.formattedValue || ''}>\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n gap: '5px',\n width: '100%',\n minWidth: 0,\n }}\n >\n {IconComponent && <IconComponent style={{ flexShrink: 0 }} />}\n <Link\n to={redirectURL}\n style={{\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n minWidth: 0,\n flex: 1,\n }}\n >\n {params.formattedValue}\n </Link>\n </div>\n </SimpleTooltip>\n );\n },\n },\n {\n field: 'visibility',\n headerName: 'Public/Private',\n flex: 1.2,\n minWidth: 150,\n headerAlign: 'center',\n valueGetter: (_, row) => (row.isPublic ? 'Public' : 'Private'),\n renderCell: (params: any) => (\n <SimpleTooltip\n title={params.formattedValue || ''}\n centered\n tooltipProps={{\n PopperProps: {\n modifiers: [{ name: 'offset', options: { offset: [0, -20] } }],\n },\n }}\n >\n {params.formattedValue}\n </SimpleTooltip>\n ),\n },\n {\n field: 'businessImpact',\n headerName: 'Business Impact',\n flex: 1.2,\n minWidth: 150,\n headerAlign: 'center',\n renderCell: (params: any) => (\n <SimpleTooltip title={params.value ?? ''} centered>\n <Chip\n label={params.value}\n colorMapping={businessImpactColorMapping}\n size=\"small\"\n variant=\"outlined\"\n chipSx={{ marginBottom: '0' }}\n />\n </SimpleTooltip>\n ),\n },\n {\n field: 'riskLevel',\n headerName: 'Risk Level',\n flex: 1,\n minWidth: 150,\n headerAlign: 'center',\n renderCell: (params: any) => (\n <SimpleTooltip title={params.value ?? ''} centered>\n <RiskLevel level={params.value} iconSize=\"large\" />\n </SimpleTooltip>\n ),\n },\n {\n field: 'riskScore',\n headerName: 'Risk Score',\n flex: 1,\n minWidth: 150,\n headerAlign: 'center',\n renderCell: (params: any) => (\n <SimpleTooltip title={params.value ?? ''} centered>\n {params.value ?? ''}\n </SimpleTooltip>\n ),\n },\n {\n field: 'languages',\n headerName: 'Languages',\n flex: 1.5,\n minWidth: 200,\n valueGetter: (_, row) => row.languages,\n renderCell: (params: any) => {\n return (\n <Box\n sx={{\n position: 'relative',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n height: '100%',\n width: '100%',\n }}\n >\n <ChipsList\n items={params.value.map((item: any) => ({\n id: item,\n label: item,\n }))}\n maxVisible={2}\n gap={0}\n variant=\"outlined\"\n />\n </Box>\n );\n },\n },\n {\n field: 'isDeployed',\n headerName: 'Deployed',\n flex: 1,\n minWidth: 150,\n headerAlign: 'center',\n valueGetter: (_, row) => (row.isDeployed ? 'Yes' : 'No'),\n renderCell: (params: any) => (\n <SimpleTooltip title={params.formattedValue || ''} centered>\n {params.formattedValue}\n </SimpleTooltip>\n ),\n },\n {\n field: 'isInternetExposed',\n headerName: 'Internet Exposed',\n flex: 1,\n minWidth: 150,\n headerAlign: 'center',\n valueGetter: (_, row) => (row.isInternetExposed ? 'Yes' : 'No'),\n renderCell: (params: any) => (\n <SimpleTooltip title={params.formattedValue || ''} centered>\n {params.formattedValue}\n </SimpleTooltip>\n ),\n },\n {\n field: 'apiCount',\n headerName: 'APIs',\n flex: 1,\n minWidth: 150,\n headerAlign: 'center',\n renderCell: (params: any) => (\n <SimpleTooltip title={params.value ?? ''} centered>\n {params.value ?? ''}\n </SimpleTooltip>\n ),\n },\n {\n field: 'sensitiveData',\n headerName: 'Sensitive Data',\n flex: 1.2,\n minWidth: 150,\n headerAlign: 'center',\n renderCell: (params: any) => {\n const sensitiveTypes = [];\n if (params.row.hasPiiData) sensitiveTypes.push('PII');\n if (params.row.hasPhiData) sensitiveTypes.push('PHI');\n if (params.row.hasPaymentsData) sensitiveTypes.push('Payments');\n const displayValue = sensitiveTypes.length > 0 ? 'Yes' : 'No';\n const tooltipText =\n sensitiveTypes.length > 0\n ? `Contains: ${sensitiveTypes.join(', ')}`\n : 'No sensitive data';\n return (\n <SimpleTooltip title={tooltipText} centered>\n <Typography>{displayValue}</Typography>\n </SimpleTooltip>\n );\n },\n },\n {\n field: 'contributorCount',\n headerName: 'Contributors',\n flex: 1,\n minWidth: 150,\n headerAlign: 'center',\n renderCell: (params: any) => (\n <SimpleTooltip title={params.value ?? ''} centered>\n {params.value ?? ''}\n </SimpleTooltip>\n ),\n },\n {\n field: 'activeSince',\n headerName: 'Active Since',\n type: 'date',\n flex: 1.2,\n minWidth: 150,\n headerAlign: 'center',\n valueGetter: (_, row) =>\n row.activeSince ? new Date(row.activeSince) : null,\n renderCell: (params: any) => (\n <SimpleTooltip\n title={params.value?.toLocaleDateString() || 'N/A'}\n centered\n >\n {params.value ? formatDate(params.value) : 'N/A'}\n </SimpleTooltip>\n ),\n },\n {\n field: 'lastActivity',\n headerName: 'Last Activity',\n type: 'date',\n flex: 1.2,\n minWidth: 150,\n headerAlign: 'center',\n valueGetter: (_, row) =>\n row.lastActivity ? new Date(row.lastActivity) : null,\n renderCell: (params: any) => (\n <SimpleTooltip\n title={params.value?.toLocaleDateString() || 'N/A'}\n centered\n >\n {params.value ? formatDate(params.value) : 'N/A'}\n </SimpleTooltip>\n ),\n },\n {\n field: 'isArchived',\n headerName: 'Archived',\n flex: 1,\n minWidth: 150,\n headerAlign: 'center',\n valueGetter: (_, row) => (row.isArchived ? 'Yes' : 'No'),\n renderCell: (params: any) => (\n <SimpleTooltip title={params.formattedValue || ''} centered>\n {params.formattedValue}\n </SimpleTooltip>\n ),\n },\n];\n\nexport const columnVisibilityModal = {\n name: true,\n visibility: true,\n businessImpact: true,\n riskLevel: true,\n riskScore: true,\n languages: true,\n isDeployed: false,\n isInternetExposed: false,\n apiCount: false,\n sensitiveData: false,\n contributorCount: false,\n activeSince: false,\n lastActivity: false,\n isArchived: false,\n};\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,258 @@
|
|
|
1
|
+
import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { useMemo, useState, useRef } from 'react';
|
|
3
|
+
import { useApi, fetchApiRef } from '@backstage/core-plugin-api';
|
|
4
|
+
import { apiiroApiRef } from '../../api/index.esm.js';
|
|
5
|
+
import { DataGrid } from '../../components/DataGrid/DataGrid.esm.js';
|
|
6
|
+
import Box from '@mui/material/Box';
|
|
7
|
+
import '@mui/material/Typography';
|
|
8
|
+
import '@mui/material/Select';
|
|
9
|
+
import '@mui/material/MenuItem';
|
|
10
|
+
import '@mui/material/Pagination';
|
|
11
|
+
import '@mui/material/styles';
|
|
12
|
+
import '@mui/x-data-grid';
|
|
13
|
+
import '@mui/material/ListItemIcon';
|
|
14
|
+
import '@mui/material/ListItemText';
|
|
15
|
+
import '@mui/icons-material';
|
|
16
|
+
import '@mui/material/TextField';
|
|
17
|
+
import '@mui/material/InputAdornment';
|
|
18
|
+
import '@mui/icons-material/Search';
|
|
19
|
+
import '@mui/icons-material/Clear';
|
|
20
|
+
import '@mui/material/IconButton';
|
|
21
|
+
import { useUrlFilters } from '../../hooks/useUrlFilters.esm.js';
|
|
22
|
+
import '@backstage/core-components';
|
|
23
|
+
import '@mui/material/SvgIcon';
|
|
24
|
+
import '@mui/material/Chip';
|
|
25
|
+
import '@mui/material/Link';
|
|
26
|
+
import 'react-dom';
|
|
27
|
+
import { RiskLevel } from '../../components/RiskLevel.esm.js';
|
|
28
|
+
import '@mui/material/Avatar';
|
|
29
|
+
import 'react-icons/vsc';
|
|
30
|
+
import 'react-icons/si';
|
|
31
|
+
import '@backstage-community/plugin-apiiro-common';
|
|
32
|
+
import { FilterDropdown } from '../../components/filters/FilterDropdown.esm.js';
|
|
33
|
+
import { RiskInsightFilter } from '../../components/filters/RiskInsightFilter.esm.js';
|
|
34
|
+
import { createDefaultQuickRanges } from '../../components/CalendarDatePicker.esm.js';
|
|
35
|
+
import { DiscoveredOnFilter } from '../../components/filters/DiscoveredOnFilter.esm.js';
|
|
36
|
+
import { ErrorSnackbar } from '../../components/common/ErrorSnackbar.esm.js';
|
|
37
|
+
import '@tanstack/react-query';
|
|
38
|
+
import { useRisksData } from '../../queries/risks.queries.esm.js';
|
|
39
|
+
import { useFilterOptionsData } from '../../queries/filterOptions.queries.esm.js';
|
|
40
|
+
import { columnVisibilityModal, risksColumns } from './tableConfig.esm.js';
|
|
41
|
+
|
|
42
|
+
const formatDateForAPI = (date) => {
|
|
43
|
+
const year = date.getFullYear();
|
|
44
|
+
const month = String(date.getMonth() + 1).padStart(2, "0");
|
|
45
|
+
const day = String(date.getDate()).padStart(2, "0");
|
|
46
|
+
return `${year}-${month}-${day}`;
|
|
47
|
+
};
|
|
48
|
+
const transformToDropdownOptions = (filterDef) => {
|
|
49
|
+
return filterDef.filterOptions.map((option) => ({
|
|
50
|
+
value: option.name,
|
|
51
|
+
label: option.displayName
|
|
52
|
+
}));
|
|
53
|
+
};
|
|
54
|
+
const transformToRiskLevelOptions = (filterDef) => {
|
|
55
|
+
return filterDef.filterOptions.map((option) => ({
|
|
56
|
+
value: option.name,
|
|
57
|
+
label: option.displayName,
|
|
58
|
+
icon: /* @__PURE__ */ jsx(RiskLevel, { level: option.name, iconSize: "large" })
|
|
59
|
+
}));
|
|
60
|
+
};
|
|
61
|
+
const transformToRiskInsightOptions = (filterDef) => {
|
|
62
|
+
return filterDef.filterOptions.map((option) => ({
|
|
63
|
+
name: option.name,
|
|
64
|
+
displayName: option.displayName,
|
|
65
|
+
description: option.displayName,
|
|
66
|
+
// Use displayName as description fallback
|
|
67
|
+
sentiment: "Neutral",
|
|
68
|
+
sortOrder: option.sortOrder,
|
|
69
|
+
group: option.group || "General",
|
|
70
|
+
groupOrder: option.groupOrder
|
|
71
|
+
}));
|
|
72
|
+
};
|
|
73
|
+
const INITIAL_SORTING = [
|
|
74
|
+
{
|
|
75
|
+
field: "riskLevel",
|
|
76
|
+
sort: "desc"
|
|
77
|
+
}
|
|
78
|
+
];
|
|
79
|
+
const PAGE_SIZE_OPTIONS = [10, 20, 50, 100];
|
|
80
|
+
const DATA_GRID_FEATURES = {
|
|
81
|
+
quickSearch: true,
|
|
82
|
+
columnPinning: true,
|
|
83
|
+
columnReordering: true,
|
|
84
|
+
customPagination: true,
|
|
85
|
+
columnMenu: true,
|
|
86
|
+
persistLayout: true
|
|
87
|
+
};
|
|
88
|
+
const Risks = ({
|
|
89
|
+
repoId,
|
|
90
|
+
entityRef
|
|
91
|
+
}) => {
|
|
92
|
+
const connectBackendApi = useApi(apiiroApiRef);
|
|
93
|
+
const { fetch } = useApi(fetchApiRef);
|
|
94
|
+
const quickRanges = useMemo(() => createDefaultQuickRanges(), []);
|
|
95
|
+
const {
|
|
96
|
+
filters,
|
|
97
|
+
setRiskCategoryFilter,
|
|
98
|
+
setRiskLevelFilter,
|
|
99
|
+
setFindingCategoryFilter,
|
|
100
|
+
setRiskInsightFilter,
|
|
101
|
+
setDiscoveredOnRange,
|
|
102
|
+
setSelectedPreset
|
|
103
|
+
} = useUrlFilters();
|
|
104
|
+
const riskCategoryFilter = filters.riskCategory;
|
|
105
|
+
const riskLevelFilter = filters.riskLevel;
|
|
106
|
+
const findingCategoryFilter = filters.findingCategory;
|
|
107
|
+
const riskInsightFilter = filters.riskInsight;
|
|
108
|
+
const discoveredOnRange = filters.discoveredOnRange;
|
|
109
|
+
const selectedPreset = filters.selectedPreset;
|
|
110
|
+
const [isPresetSelection, setIsPresetSelection] = useState(false);
|
|
111
|
+
const presetSelectionRef = useRef(false);
|
|
112
|
+
const {
|
|
113
|
+
filterOptionsData,
|
|
114
|
+
filterOptionsDataLoading,
|
|
115
|
+
filterOptionsDataError
|
|
116
|
+
} = useFilterOptionsData({
|
|
117
|
+
connectApi: connectBackendApi,
|
|
118
|
+
fetchApi: fetch
|
|
119
|
+
});
|
|
120
|
+
const riskCategoryOptions = useMemo(() => {
|
|
121
|
+
const filterDef = filterOptionsData?.find((f) => f.name === "RiskCategory");
|
|
122
|
+
return filterDef ? transformToDropdownOptions(filterDef) : [];
|
|
123
|
+
}, [filterOptionsData]);
|
|
124
|
+
const riskLevelOptions = useMemo(() => {
|
|
125
|
+
const filterDef = filterOptionsData?.find((f) => f.name === "RiskLevel");
|
|
126
|
+
return filterDef ? transformToRiskLevelOptions(filterDef) : [];
|
|
127
|
+
}, [filterOptionsData]);
|
|
128
|
+
const findingCategoryOptions = useMemo(() => {
|
|
129
|
+
const filterDef = filterOptionsData?.find(
|
|
130
|
+
(f) => f.name === "FindingCategory"
|
|
131
|
+
);
|
|
132
|
+
return filterDef ? transformToDropdownOptions(filterDef) : [];
|
|
133
|
+
}, [filterOptionsData]);
|
|
134
|
+
const riskInsightOptions = useMemo(() => {
|
|
135
|
+
const filterDef = filterOptionsData?.find((f) => f.name === "RiskInsight");
|
|
136
|
+
return filterDef ? transformToRiskInsightOptions(filterDef) : [];
|
|
137
|
+
}, [filterOptionsData]);
|
|
138
|
+
const { risksData, risksDataLoading, risksDataError } = useRisksData({
|
|
139
|
+
connectApi: connectBackendApi,
|
|
140
|
+
fetchApi: fetch,
|
|
141
|
+
repositoryKey: repoId,
|
|
142
|
+
entityRef,
|
|
143
|
+
filters: {
|
|
144
|
+
...riskCategoryFilter.length > 0 && {
|
|
145
|
+
RiskCategory: riskCategoryFilter
|
|
146
|
+
},
|
|
147
|
+
...riskLevelFilter.length > 0 && { RiskLevel: riskLevelFilter },
|
|
148
|
+
...findingCategoryFilter.length > 0 && {
|
|
149
|
+
FindingCategory: findingCategoryFilter
|
|
150
|
+
},
|
|
151
|
+
...riskInsightFilter.length > 0 && { RiskInsight: riskInsightFilter },
|
|
152
|
+
...Array.isArray(discoveredOnRange) && discoveredOnRange[0] instanceof Date && discoveredOnRange[1] instanceof Date && {
|
|
153
|
+
DiscoveredOn: {
|
|
154
|
+
start: formatDateForAPI(discoveredOnRange[0]),
|
|
155
|
+
end: formatDateForAPI(discoveredOnRange[1])
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
});
|
|
160
|
+
const rows = useMemo(() => risksData?.risks || [], [risksData?.risks]);
|
|
161
|
+
const handlePresetSelect = (range) => {
|
|
162
|
+
setIsPresetSelection(true);
|
|
163
|
+
presetSelectionRef.current = true;
|
|
164
|
+
setSelectedPreset(range.value);
|
|
165
|
+
const nextValue = range.getRange();
|
|
166
|
+
setDiscoveredOnRange(nextValue ?? []);
|
|
167
|
+
};
|
|
168
|
+
const handleCalendarChange = (value) => {
|
|
169
|
+
if (isPresetSelection || presetSelectionRef.current) {
|
|
170
|
+
setIsPresetSelection(false);
|
|
171
|
+
presetSelectionRef.current = false;
|
|
172
|
+
return;
|
|
173
|
+
}
|
|
174
|
+
setDiscoveredOnRange(value);
|
|
175
|
+
setSelectedPreset("");
|
|
176
|
+
};
|
|
177
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
178
|
+
/* @__PURE__ */ jsx(
|
|
179
|
+
DataGrid,
|
|
180
|
+
{
|
|
181
|
+
getRowId: (row) => row.id,
|
|
182
|
+
loading: risksDataLoading,
|
|
183
|
+
tableKey: "risks",
|
|
184
|
+
columns: risksColumns,
|
|
185
|
+
rows,
|
|
186
|
+
dataLabel: "risks",
|
|
187
|
+
searchBarPlaceHolder: "Search risk name...",
|
|
188
|
+
customFilters: /* @__PURE__ */ jsxs(Box, { sx: { display: "flex", gap: 1, flexWrap: "wrap" }, children: [
|
|
189
|
+
/* @__PURE__ */ jsx(
|
|
190
|
+
FilterDropdown,
|
|
191
|
+
{
|
|
192
|
+
label: "Risk category",
|
|
193
|
+
options: riskCategoryOptions,
|
|
194
|
+
selectedValues: riskCategoryFilter,
|
|
195
|
+
onChange: setRiskCategoryFilter,
|
|
196
|
+
loading: filterOptionsDataLoading
|
|
197
|
+
}
|
|
198
|
+
),
|
|
199
|
+
/* @__PURE__ */ jsx(
|
|
200
|
+
FilterDropdown,
|
|
201
|
+
{
|
|
202
|
+
label: "Risk level",
|
|
203
|
+
options: riskLevelOptions,
|
|
204
|
+
selectedValues: riskLevelFilter,
|
|
205
|
+
onChange: setRiskLevelFilter,
|
|
206
|
+
loading: filterOptionsDataLoading
|
|
207
|
+
}
|
|
208
|
+
),
|
|
209
|
+
/* @__PURE__ */ jsx(
|
|
210
|
+
FilterDropdown,
|
|
211
|
+
{
|
|
212
|
+
label: "Finding category",
|
|
213
|
+
options: findingCategoryOptions,
|
|
214
|
+
selectedValues: findingCategoryFilter,
|
|
215
|
+
onChange: setFindingCategoryFilter,
|
|
216
|
+
loading: filterOptionsDataLoading
|
|
217
|
+
}
|
|
218
|
+
),
|
|
219
|
+
/* @__PURE__ */ jsx(
|
|
220
|
+
RiskInsightFilter,
|
|
221
|
+
{
|
|
222
|
+
label: "Insights",
|
|
223
|
+
options: riskInsightOptions,
|
|
224
|
+
selectedValues: riskInsightFilter,
|
|
225
|
+
onChange: setRiskInsightFilter,
|
|
226
|
+
loading: filterOptionsDataLoading
|
|
227
|
+
}
|
|
228
|
+
),
|
|
229
|
+
/* @__PURE__ */ jsx(
|
|
230
|
+
DiscoveredOnFilter,
|
|
231
|
+
{
|
|
232
|
+
value: discoveredOnRange,
|
|
233
|
+
onChange: handleCalendarChange,
|
|
234
|
+
selectedQuickRange: selectedPreset,
|
|
235
|
+
onQuickRangeSelect: handlePresetSelect,
|
|
236
|
+
quickRanges,
|
|
237
|
+
loading: filterOptionsDataLoading
|
|
238
|
+
}
|
|
239
|
+
)
|
|
240
|
+
] }),
|
|
241
|
+
features: DATA_GRID_FEATURES,
|
|
242
|
+
initialState: {
|
|
243
|
+
sorting: {
|
|
244
|
+
sortModel: INITIAL_SORTING
|
|
245
|
+
}
|
|
246
|
+
},
|
|
247
|
+
initialPageSize: PAGE_SIZE_OPTIONS[0],
|
|
248
|
+
pageSizeOptions: PAGE_SIZE_OPTIONS,
|
|
249
|
+
columnVisibility: columnVisibilityModal
|
|
250
|
+
}
|
|
251
|
+
),
|
|
252
|
+
/* @__PURE__ */ jsx(ErrorSnackbar, { error: risksDataError }),
|
|
253
|
+
/* @__PURE__ */ jsx(ErrorSnackbar, { error: filterOptionsDataError })
|
|
254
|
+
] });
|
|
255
|
+
};
|
|
256
|
+
|
|
257
|
+
export { Risks };
|
|
258
|
+
//# sourceMappingURL=Risks.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Risks.esm.js","sources":["../../../src/pages/Risks/Risks.tsx"],"sourcesContent":["/*\n * Copyright 2025 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { useMemo, useRef, useState } from 'react';\n\nimport { fetchApiRef, useApi } from '@backstage/core-plugin-api';\nimport { apiiroApiRef } from '../../api';\nimport { DataGrid } from '../../components/DataGrid';\nimport { useUrlFilters } from '../../hooks';\nimport {\n createDefaultQuickRanges,\n CalendarQuickRange,\n CalendarDateValue,\n DiscoveredOnFilter,\n FilterDropdown,\n RiskInsightFilter,\n RiskInsightOption,\n RiskLevel,\n} from '../../components';\nimport { ErrorSnackbar } from '../../components/common/ErrorSnackbar';\nimport { useRisksData } from '../../queries';\nimport {\n useFilterOptionsData,\n FilterDefinition,\n} from '../../queries/filterOptions.queries';\nimport { columnVisibilityModal, risksColumns } from './tableConfig';\nimport Box from '@mui/material/Box';\n\n// Helper function to format date without timezone conversion\nconst formatDateForAPI = (date: Date): string => {\n const year = date.getFullYear();\n const month = String(date.getMonth() + 1).padStart(2, '0');\n const day = String(date.getDate()).padStart(2, '0');\n return `${year}-${month}-${day}`;\n};\n\n// Helper functions to transform API data to component format\nconst transformToDropdownOptions = (filterDef: FilterDefinition) => {\n return filterDef.filterOptions.map(option => ({\n value: option.name,\n label: option.displayName,\n }));\n};\n\nconst transformToRiskLevelOptions = (filterDef: FilterDefinition) => {\n return filterDef.filterOptions.map(option => ({\n value: option.name,\n label: option.displayName,\n icon: <RiskLevel level={option.name as any} iconSize=\"large\" />,\n }));\n};\n\nconst transformToRiskInsightOptions = (\n filterDef: FilterDefinition,\n): RiskInsightOption[] => {\n return filterDef.filterOptions.map(option => ({\n name: option.name,\n displayName: option.displayName,\n description: option.displayName, // Use displayName as description fallback\n sentiment: 'Neutral' as const,\n sortOrder: option.sortOrder,\n group: option.group || 'General',\n groupOrder: option.groupOrder,\n }));\n};\n\n// Constants to prevent recreation on every render\nconst INITIAL_SORTING = [\n {\n field: 'riskLevel',\n sort: 'desc' as const,\n },\n];\n\nconst PAGE_SIZE_OPTIONS = [10, 20, 50, 100];\n\nconst DATA_GRID_FEATURES = {\n quickSearch: true,\n columnPinning: true,\n columnReordering: true,\n customPagination: true,\n columnMenu: true,\n persistLayout: true,\n} as const;\n\nexport const Risks = ({\n repoId,\n entityRef,\n}: {\n repoId: string | undefined;\n entityRef: string;\n}) => {\n const connectBackendApi = useApi(apiiroApiRef);\n const { fetch } = useApi(fetchApiRef);\n const quickRanges = useMemo(() => createDefaultQuickRanges(), []);\n\n // Use URL filters hook\n const {\n filters,\n setRiskCategoryFilter,\n setRiskLevelFilter,\n setFindingCategoryFilter,\n setRiskInsightFilter,\n setDiscoveredOnRange,\n setSelectedPreset,\n } = useUrlFilters();\n\n // Extract filter values from the hook\n const riskCategoryFilter = filters.riskCategory;\n const riskLevelFilter = filters.riskLevel;\n const findingCategoryFilter = filters.findingCategory;\n const riskInsightFilter = filters.riskInsight;\n const discoveredOnRange = filters.discoveredOnRange;\n const selectedPreset = filters.selectedPreset;\n\n const [isPresetSelection, setIsPresetSelection] = useState(false);\n const presetSelectionRef = useRef(false);\n\n // Fetch filter options from API\n const {\n filterOptionsData,\n filterOptionsDataLoading,\n filterOptionsDataError,\n } = useFilterOptionsData({\n connectApi: connectBackendApi,\n fetchApi: fetch,\n });\n\n // Transform API data to component format\n const riskCategoryOptions = useMemo(() => {\n const filterDef = filterOptionsData?.find(f => f.name === 'RiskCategory');\n return filterDef ? transformToDropdownOptions(filterDef) : [];\n }, [filterOptionsData]);\n\n const riskLevelOptions = useMemo(() => {\n const filterDef = filterOptionsData?.find(f => f.name === 'RiskLevel');\n return filterDef ? transformToRiskLevelOptions(filterDef) : [];\n }, [filterOptionsData]);\n\n const findingCategoryOptions = useMemo(() => {\n const filterDef = filterOptionsData?.find(\n f => f.name === 'FindingCategory',\n );\n return filterDef ? transformToDropdownOptions(filterDef) : [];\n }, [filterOptionsData]);\n\n const riskInsightOptions = useMemo(() => {\n const filterDef = filterOptionsData?.find(f => f.name === 'RiskInsight');\n return filterDef ? transformToRiskInsightOptions(filterDef) : [];\n }, [filterOptionsData]);\n\n const { risksData, risksDataLoading, risksDataError } = useRisksData({\n connectApi: connectBackendApi,\n fetchApi: fetch,\n repositoryKey: repoId!,\n entityRef: entityRef,\n filters: {\n ...(riskCategoryFilter.length > 0 && {\n RiskCategory: riskCategoryFilter,\n }),\n ...(riskLevelFilter.length > 0 && { RiskLevel: riskLevelFilter }),\n ...(findingCategoryFilter.length > 0 && {\n FindingCategory: findingCategoryFilter,\n }),\n ...(riskInsightFilter.length > 0 && { RiskInsight: riskInsightFilter }),\n ...(Array.isArray(discoveredOnRange) &&\n discoveredOnRange[0] instanceof Date &&\n discoveredOnRange[1] instanceof Date && {\n DiscoveredOn: {\n start: formatDateForAPI(discoveredOnRange[0]),\n end: formatDateForAPI(discoveredOnRange[1]),\n },\n }),\n },\n });\n\n // Memoize rows to prevent unnecessary re-renders that cause pagination flickering\n const rows = useMemo(() => risksData?.risks || [], [risksData?.risks]);\n\n const handlePresetSelect = (range: CalendarQuickRange) => {\n setIsPresetSelection(true);\n presetSelectionRef.current = true;\n setSelectedPreset(range.value);\n const nextValue = range.getRange();\n setDiscoveredOnRange(nextValue ?? []);\n };\n\n const handleCalendarChange = (value: CalendarDateValue) => {\n if (isPresetSelection || presetSelectionRef.current) {\n setIsPresetSelection(false);\n presetSelectionRef.current = false;\n return;\n }\n setDiscoveredOnRange(value);\n setSelectedPreset('');\n };\n\n return (\n <>\n <DataGrid<any>\n getRowId={row => row.id}\n loading={risksDataLoading}\n tableKey=\"risks\"\n columns={risksColumns}\n rows={rows}\n dataLabel=\"risks\"\n searchBarPlaceHolder=\"Search risk name...\"\n customFilters={\n <Box sx={{ display: 'flex', gap: 1, flexWrap: 'wrap' }}>\n <FilterDropdown\n label=\"Risk category\"\n options={riskCategoryOptions}\n selectedValues={riskCategoryFilter}\n onChange={setRiskCategoryFilter}\n loading={filterOptionsDataLoading}\n />\n <FilterDropdown\n label=\"Risk level\"\n options={riskLevelOptions}\n selectedValues={riskLevelFilter}\n onChange={setRiskLevelFilter}\n loading={filterOptionsDataLoading}\n />\n <FilterDropdown\n label=\"Finding category\"\n options={findingCategoryOptions}\n selectedValues={findingCategoryFilter}\n onChange={setFindingCategoryFilter}\n loading={filterOptionsDataLoading}\n />\n <RiskInsightFilter\n label=\"Insights\"\n options={riskInsightOptions}\n selectedValues={riskInsightFilter}\n onChange={setRiskInsightFilter}\n loading={filterOptionsDataLoading}\n />\n <DiscoveredOnFilter\n value={discoveredOnRange}\n onChange={handleCalendarChange}\n selectedQuickRange={selectedPreset}\n onQuickRangeSelect={handlePresetSelect}\n quickRanges={quickRanges}\n loading={filterOptionsDataLoading}\n />\n </Box>\n }\n features={DATA_GRID_FEATURES}\n initialState={{\n sorting: {\n sortModel: INITIAL_SORTING,\n },\n }}\n initialPageSize={PAGE_SIZE_OPTIONS[0]}\n pageSizeOptions={PAGE_SIZE_OPTIONS}\n columnVisibility={columnVisibilityModal}\n />\n\n <ErrorSnackbar error={risksDataError} />\n <ErrorSnackbar error={filterOptionsDataError} />\n </>\n );\n};\n"],"names":[],"mappings":"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"}
|