@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.
Files changed (223) hide show
  1. package/CHANGELOG.md +12 -0
  2. package/README.md +232 -0
  3. package/config.d.ts +30 -0
  4. package/dist/App.esm.js +12 -0
  5. package/dist/App.esm.js.map +1 -0
  6. package/dist/api/index.esm.js +71 -0
  7. package/dist/api/index.esm.js.map +1 -0
  8. package/dist/assets/BulleyeIcon.esm.js +454 -0
  9. package/dist/assets/BulleyeIcon.esm.js.map +1 -0
  10. package/dist/assets/NoResultIcon.esm.js +146 -0
  11. package/dist/assets/NoResultIcon.esm.js.map +1 -0
  12. package/dist/assets/RiskIcon.esm.js +27 -0
  13. package/dist/assets/RiskIcon.esm.js.map +1 -0
  14. package/dist/assets/SettingIcon.esm.js +49 -0
  15. package/dist/assets/SettingIcon.esm.js.map +1 -0
  16. package/dist/assets/apiiroLogo/apiiroLogo.esm.js +21 -0
  17. package/dist/assets/apiiroLogo/apiiroLogo.esm.js.map +1 -0
  18. package/dist/assets/apiiroLogo/apiiroSidebar.esm.js +23 -0
  19. package/dist/assets/apiiroLogo/apiiroSidebar.esm.js.map +1 -0
  20. package/dist/assets/apiiroLogo/apiiroSmall.esm.js +19 -0
  21. package/dist/assets/apiiroLogo/apiiroSmall.esm.js.map +1 -0
  22. package/dist/assets/languageIcons/C.esm.js +7 -0
  23. package/dist/assets/languageIcons/C.esm.js.map +1 -0
  24. package/dist/assets/languageIcons/Cicd.esm.js +7 -0
  25. package/dist/assets/languageIcons/Cicd.esm.js.map +1 -0
  26. package/dist/assets/languageIcons/Clojure.esm.js +7 -0
  27. package/dist/assets/languageIcons/Clojure.esm.js.map +1 -0
  28. package/dist/assets/languageIcons/Cpp.esm.js +7 -0
  29. package/dist/assets/languageIcons/Cpp.esm.js.map +1 -0
  30. package/dist/assets/languageIcons/Csharp.esm.js +7 -0
  31. package/dist/assets/languageIcons/Csharp.esm.js.map +1 -0
  32. package/dist/assets/languageIcons/Dart.esm.js +7 -0
  33. package/dist/assets/languageIcons/Dart.esm.js.map +1 -0
  34. package/dist/assets/languageIcons/Go.esm.js +7 -0
  35. package/dist/assets/languageIcons/Go.esm.js.map +1 -0
  36. package/dist/assets/languageIcons/Groovy.esm.js +7 -0
  37. package/dist/assets/languageIcons/Groovy.esm.js.map +1 -0
  38. package/dist/assets/languageIcons/HTML.esm.js +7 -0
  39. package/dist/assets/languageIcons/HTML.esm.js.map +1 -0
  40. package/dist/assets/languageIcons/HclLanguage.esm.js +7 -0
  41. package/dist/assets/languageIcons/HclLanguage.esm.js.map +1 -0
  42. package/dist/assets/languageIcons/Java.esm.js +7 -0
  43. package/dist/assets/languageIcons/Java.esm.js.map +1 -0
  44. package/dist/assets/languageIcons/Javascript.esm.js +7 -0
  45. package/dist/assets/languageIcons/Javascript.esm.js.map +1 -0
  46. package/dist/assets/languageIcons/Kotlin.esm.js +7 -0
  47. package/dist/assets/languageIcons/Kotlin.esm.js.map +1 -0
  48. package/dist/assets/languageIcons/ObjectiveC.esm.js +7 -0
  49. package/dist/assets/languageIcons/ObjectiveC.esm.js.map +1 -0
  50. package/dist/assets/languageIcons/PHP.esm.js +7 -0
  51. package/dist/assets/languageIcons/PHP.esm.js.map +1 -0
  52. package/dist/assets/languageIcons/Perl.esm.js +13 -0
  53. package/dist/assets/languageIcons/Perl.esm.js.map +1 -0
  54. package/dist/assets/languageIcons/Python.esm.js +7 -0
  55. package/dist/assets/languageIcons/Python.esm.js.map +1 -0
  56. package/dist/assets/languageIcons/Ruby.esm.js +7 -0
  57. package/dist/assets/languageIcons/Ruby.esm.js.map +1 -0
  58. package/dist/assets/languageIcons/Rust.esm.js +7 -0
  59. package/dist/assets/languageIcons/Rust.esm.js.map +1 -0
  60. package/dist/assets/languageIcons/Scala.esm.js +7 -0
  61. package/dist/assets/languageIcons/Scala.esm.js.map +1 -0
  62. package/dist/assets/languageIcons/Swift.esm.js +7 -0
  63. package/dist/assets/languageIcons/Swift.esm.js.map +1 -0
  64. package/dist/assets/languageIcons/Terraform.esm.js +7 -0
  65. package/dist/assets/languageIcons/Terraform.esm.js.map +1 -0
  66. package/dist/assets/languageIcons/Typescript.esm.js +7 -0
  67. package/dist/assets/languageIcons/Typescript.esm.js.map +1 -0
  68. package/dist/assets/languageIcons/Unknown.esm.js +7 -0
  69. package/dist/assets/languageIcons/Unknown.esm.js.map +1 -0
  70. package/dist/assets/languageIcons/VB.esm.js +10 -0
  71. package/dist/assets/languageIcons/VB.esm.js.map +1 -0
  72. package/dist/assets/languageIcons/YAML.esm.js +7 -0
  73. package/dist/assets/languageIcons/YAML.esm.js.map +1 -0
  74. package/dist/assets/providerIcons/Azure.esm.js +7 -0
  75. package/dist/assets/providerIcons/Azure.esm.js.map +1 -0
  76. package/dist/assets/providerIcons/Bitbucket.esm.js +7 -0
  77. package/dist/assets/providerIcons/Bitbucket.esm.js.map +1 -0
  78. package/dist/assets/providerIcons/Gitlab.esm.js +7 -0
  79. package/dist/assets/providerIcons/Gitlab.esm.js.map +1 -0
  80. package/dist/components/ApiiroSidebar.esm.js +10 -0
  81. package/dist/components/ApiiroSidebar.esm.js.map +1 -0
  82. package/dist/components/ApplicationsList/ApplicationsList.esm.js +196 -0
  83. package/dist/components/ApplicationsList/ApplicationsList.esm.js.map +1 -0
  84. package/dist/components/CalendarDatePicker.esm.js +154 -0
  85. package/dist/components/CalendarDatePicker.esm.js.map +1 -0
  86. package/dist/components/CalendarDatePicker.styles.esm.js +198 -0
  87. package/dist/components/CalendarDatePicker.styles.esm.js.map +1 -0
  88. package/dist/components/Chip.esm.js +60 -0
  89. package/dist/components/Chip.esm.js.map +1 -0
  90. package/dist/components/ChipsList.esm.js +207 -0
  91. package/dist/components/ChipsList.esm.js.map +1 -0
  92. package/dist/components/ComponentDisplay.esm.js +42 -0
  93. package/dist/components/ComponentDisplay.esm.js.map +1 -0
  94. package/dist/components/DataGrid/CustomColumnMenu.esm.js +29 -0
  95. package/dist/components/DataGrid/CustomColumnMenu.esm.js.map +1 -0
  96. package/dist/components/DataGrid/CustomPagination.esm.js +113 -0
  97. package/dist/components/DataGrid/CustomPagination.esm.js.map +1 -0
  98. package/dist/components/DataGrid/CustomSearchToolbar.esm.js +117 -0
  99. package/dist/components/DataGrid/CustomSearchToolbar.esm.js.map +1 -0
  100. package/dist/components/DataGrid/DataGrid.esm.js +336 -0
  101. package/dist/components/DataGrid/DataGrid.esm.js.map +1 -0
  102. package/dist/components/DataGrid/PinColumnMenuItem.esm.js +24 -0
  103. package/dist/components/DataGrid/PinColumnMenuItem.esm.js.map +1 -0
  104. package/dist/components/DueDate.esm.js +34 -0
  105. package/dist/components/DueDate.esm.js.map +1 -0
  106. package/dist/components/Header.esm.js +27 -0
  107. package/dist/components/Header.esm.js.map +1 -0
  108. package/dist/components/MainContributors/MainContributors.esm.js +62 -0
  109. package/dist/components/MainContributors/MainContributors.esm.js.map +1 -0
  110. package/dist/components/MetricsGroup/TabMetricsGroup.esm.js +37 -0
  111. package/dist/components/MetricsGroup/TabMetricsGroup.esm.js.map +1 -0
  112. package/dist/components/MetricsGroup/WidgetMetricsGroup.esm.js +36 -0
  113. package/dist/components/MetricsGroup/WidgetMetricsGroup.esm.js.map +1 -0
  114. package/dist/components/RepositoryDisplay/RepositoryDisplay.esm.js +121 -0
  115. package/dist/components/RepositoryDisplay/RepositoryDisplay.esm.js.map +1 -0
  116. package/dist/components/RiskLevel.esm.js +88 -0
  117. package/dist/components/RiskLevel.esm.js.map +1 -0
  118. package/dist/components/RiskStatus.esm.js +58 -0
  119. package/dist/components/RiskStatus.esm.js.map +1 -0
  120. package/dist/components/SimpleTooltip.esm.js +24 -0
  121. package/dist/components/SimpleTooltip.esm.js.map +1 -0
  122. package/dist/components/SourcesDisplay.esm.js +47 -0
  123. package/dist/components/SourcesDisplay.esm.js.map +1 -0
  124. package/dist/components/TagsList/TagsList.esm.js +38 -0
  125. package/dist/components/TagsList/TagsList.esm.js.map +1 -0
  126. package/dist/components/TeamsDisplay.esm.js +47 -0
  127. package/dist/components/TeamsDisplay.esm.js.map +1 -0
  128. package/dist/components/charts/ColumnChart.esm.js +402 -0
  129. package/dist/components/charts/ColumnChart.esm.js.map +1 -0
  130. package/dist/components/charts/GaugeChart.esm.js +249 -0
  131. package/dist/components/charts/GaugeChart.esm.js.map +1 -0
  132. package/dist/components/charts/LineChart.esm.js +328 -0
  133. package/dist/components/charts/LineChart.esm.js.map +1 -0
  134. package/dist/components/charts/PieChart.esm.js +233 -0
  135. package/dist/components/charts/PieChart.esm.js.map +1 -0
  136. package/dist/components/common/ChartBox.esm.js +88 -0
  137. package/dist/components/common/ChartBox.esm.js.map +1 -0
  138. package/dist/components/common/CustomTooltip.esm.js +255 -0
  139. package/dist/components/common/CustomTooltip.esm.js.map +1 -0
  140. package/dist/components/common/ErrorSnackbar.esm.js +39 -0
  141. package/dist/components/common/ErrorSnackbar.esm.js.map +1 -0
  142. package/dist/components/common/NotFound.esm.js +30 -0
  143. package/dist/components/common/NotFound.esm.js.map +1 -0
  144. package/dist/components/common/SomethingWentWrong.esm.js +35 -0
  145. package/dist/components/common/SomethingWentWrong.esm.js.map +1 -0
  146. package/dist/components/common/languageIcons.esm.js +61 -0
  147. package/dist/components/common/languageIcons.esm.js.map +1 -0
  148. package/dist/components/common/logoSpinner.esm.js +28 -0
  149. package/dist/components/common/logoSpinner.esm.js.map +1 -0
  150. package/dist/components/common/scmProviders.esm.js +41 -0
  151. package/dist/components/common/scmProviders.esm.js.map +1 -0
  152. package/dist/components/filters/DiscoveredOnFilter.esm.js +284 -0
  153. package/dist/components/filters/DiscoveredOnFilter.esm.js.map +1 -0
  154. package/dist/components/filters/FilterDropdown.esm.js +325 -0
  155. package/dist/components/filters/FilterDropdown.esm.js.map +1 -0
  156. package/dist/components/filters/FilterDropdownClear.esm.js +45 -0
  157. package/dist/components/filters/FilterDropdownClear.esm.js.map +1 -0
  158. package/dist/components/filters/FilterDropdownList.esm.js +102 -0
  159. package/dist/components/filters/FilterDropdownList.esm.js.map +1 -0
  160. package/dist/components/filters/FilterDropdownSearch.esm.js +65 -0
  161. package/dist/components/filters/FilterDropdownSearch.esm.js.map +1 -0
  162. package/dist/components/filters/RiskInsightFilter.esm.js +579 -0
  163. package/dist/components/filters/RiskInsightFilter.esm.js.map +1 -0
  164. package/dist/components/tiles/MttrVsSLATile.esm.js +170 -0
  165. package/dist/components/tiles/MttrVsSLATile.esm.js.map +1 -0
  166. package/dist/components/tiles/RiskOverTimeTile.esm.js +311 -0
  167. package/dist/components/tiles/RiskOverTimeTile.esm.js.map +1 -0
  168. package/dist/components/tiles/SLAAdherenceTile.esm.js +115 -0
  169. package/dist/components/tiles/SLAAdherenceTile.esm.js.map +1 -0
  170. package/dist/components/tiles/StatusTile.esm.js +235 -0
  171. package/dist/components/tiles/StatusTile.esm.js.map +1 -0
  172. package/dist/components/tiles/TopLanguagesTile.esm.js +234 -0
  173. package/dist/components/tiles/TopLanguagesTile.esm.js.map +1 -0
  174. package/dist/components/tiles/TopRiskTile.esm.js +208 -0
  175. package/dist/components/tiles/TopRiskTile.esm.js.map +1 -0
  176. package/dist/hooks/useUrlFilters.esm.js +102 -0
  177. package/dist/hooks/useUrlFilters.esm.js.map +1 -0
  178. package/dist/index.d.ts +28 -0
  179. package/dist/index.esm.js +42 -0
  180. package/dist/index.esm.js.map +1 -0
  181. package/dist/pages/Repositories/Repositories.esm.js +102 -0
  182. package/dist/pages/Repositories/Repositories.esm.js.map +1 -0
  183. package/dist/pages/Repositories/tableConfig.esm.js +294 -0
  184. package/dist/pages/Repositories/tableConfig.esm.js.map +1 -0
  185. package/dist/pages/Risks/Risks.esm.js +258 -0
  186. package/dist/pages/Risks/Risks.esm.js.map +1 -0
  187. package/dist/pages/Risks/tableConfig.esm.js +305 -0
  188. package/dist/pages/Risks/tableConfig.esm.js.map +1 -0
  189. package/dist/pages/tab/Tab.esm.js +147 -0
  190. package/dist/pages/tab/Tab.esm.js.map +1 -0
  191. package/dist/pages/tab/TabProvider.esm.js +11 -0
  192. package/dist/pages/tab/TabProvider.esm.js.map +1 -0
  193. package/dist/pages/widget/Widget.esm.js +161 -0
  194. package/dist/pages/widget/Widget.esm.js.map +1 -0
  195. package/dist/pages/widget/WidgetProvider.esm.js +12 -0
  196. package/dist/pages/widget/WidgetProvider.esm.js.map +1 -0
  197. package/dist/plugin.esm.js +30 -0
  198. package/dist/plugin.esm.js.map +1 -0
  199. package/dist/queries/filterOptions.queries.esm.js +46 -0
  200. package/dist/queries/filterOptions.queries.esm.js.map +1 -0
  201. package/dist/queries/mttr-statistics.queries.esm.js +61 -0
  202. package/dist/queries/mttr-statistics.queries.esm.js.map +1 -0
  203. package/dist/queries/repository.queries.esm.js +60 -0
  204. package/dist/queries/repository.queries.esm.js.map +1 -0
  205. package/dist/queries/risk-score-over-time.queries.esm.js +61 -0
  206. package/dist/queries/risk-score-over-time.queries.esm.js.map +1 -0
  207. package/dist/queries/risks.queries.esm.js +65 -0
  208. package/dist/queries/risks.queries.esm.js.map +1 -0
  209. package/dist/queries/sla-breach.queries.esm.js +57 -0
  210. package/dist/queries/sla-breach.queries.esm.js.map +1 -0
  211. package/dist/queries/top-risks.queries.esm.js +47 -0
  212. package/dist/queries/top-risks.queries.esm.js.map +1 -0
  213. package/dist/routes.esm.js +8 -0
  214. package/dist/routes.esm.js.map +1 -0
  215. package/dist/theme/themeUtils.esm.js +290 -0
  216. package/dist/theme/themeUtils.esm.js.map +1 -0
  217. package/dist/utils/dateFormatter.esm.js +67 -0
  218. package/dist/utils/dateFormatter.esm.js.map +1 -0
  219. package/dist/utils/numberFormatter.esm.js +21 -0
  220. package/dist/utils/numberFormatter.esm.js.map +1 -0
  221. package/dist/utils/utils.esm.js +27 -0
  222. package/dist/utils/utils.esm.js.map +1 -0
  223. 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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"}