@kuadrant/kuadrant-backstage-plugin-frontend 0.0.1-test.1-1593c3ec

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 (39) hide show
  1. package/README.md +491 -0
  2. package/dist/components/ApiAccessCard/ApiAccessCard.esm.js +42 -0
  3. package/dist/components/ApiAccessCard/ApiAccessCard.esm.js.map +1 -0
  4. package/dist/components/ApiAccessCard/index.esm.js +2 -0
  5. package/dist/components/ApiAccessCard/index.esm.js.map +1 -0
  6. package/dist/components/ApiKeyManagementTab/ApiKeyManagementTab.esm.js +441 -0
  7. package/dist/components/ApiKeyManagementTab/ApiKeyManagementTab.esm.js.map +1 -0
  8. package/dist/components/ApiKeyManagementTab/index.esm.js +2 -0
  9. package/dist/components/ApiKeyManagementTab/index.esm.js.map +1 -0
  10. package/dist/components/ApiProductInfoCard/ApiProductInfoCard.esm.js +47 -0
  11. package/dist/components/ApiProductInfoCard/ApiProductInfoCard.esm.js.map +1 -0
  12. package/dist/components/ApiProductInfoCard/index.esm.js +2 -0
  13. package/dist/components/ApiProductInfoCard/index.esm.js.map +1 -0
  14. package/dist/components/ApprovalQueueCard/ApprovalQueueCard.esm.js +349 -0
  15. package/dist/components/ApprovalQueueCard/ApprovalQueueCard.esm.js.map +1 -0
  16. package/dist/components/ApprovalQueueCard/index.esm.js +2 -0
  17. package/dist/components/ApprovalQueueCard/index.esm.js.map +1 -0
  18. package/dist/components/CreateAPIProductDialog/CreateAPIProductDialog.esm.js +289 -0
  19. package/dist/components/CreateAPIProductDialog/CreateAPIProductDialog.esm.js.map +1 -0
  20. package/dist/components/KuadrantPage/KuadrantPage.esm.js +198 -0
  21. package/dist/components/KuadrantPage/KuadrantPage.esm.js.map +1 -0
  22. package/dist/components/KuadrantPage/index.esm.js +2 -0
  23. package/dist/components/KuadrantPage/index.esm.js.map +1 -0
  24. package/dist/components/PermissionGate/PermissionGate.esm.js +33 -0
  25. package/dist/components/PermissionGate/PermissionGate.esm.js.map +1 -0
  26. package/dist/components/PlanPolicyDetailPage/PlanPolicyDetailPage.esm.js +89 -0
  27. package/dist/components/PlanPolicyDetailPage/PlanPolicyDetailPage.esm.js.map +1 -0
  28. package/dist/components/PlanPolicyDetailPage/index.esm.js +2 -0
  29. package/dist/components/PlanPolicyDetailPage/index.esm.js.map +1 -0
  30. package/dist/hooks/useUserRole.esm.js +49 -0
  31. package/dist/hooks/useUserRole.esm.js.map +1 -0
  32. package/dist/index.d.ts +31 -0
  33. package/dist/index.esm.js +6 -0
  34. package/dist/index.esm.js.map +1 -0
  35. package/dist/plugin.esm.js +68 -0
  36. package/dist/plugin.esm.js.map +1 -0
  37. package/dist/routes.esm.js +13 -0
  38. package/dist/routes.esm.js.map +1 -0
  39. package/package.json +85 -0
@@ -0,0 +1,349 @@
1
+ import React, { useState } from 'react';
2
+ import { useApi, configApiRef, fetchApiRef, identityApiRef } from '@backstage/core-plugin-api';
3
+ import { useAsync } from 'react-use';
4
+ import { Progress, ResponseErrorPanel, InfoCard, Table } from '@backstage/core-components';
5
+ import { Box, Typography, Dialog, DialogTitle, DialogContent, TextField, DialogActions, Button, Chip } from '@material-ui/core';
6
+ import CheckCircleIcon from '@material-ui/icons/CheckCircle';
7
+ import CancelIcon from '@material-ui/icons/Cancel';
8
+
9
+ const ApprovalDialog = ({ open, request, action, onClose, onConfirm }) => {
10
+ const [comment, setComment] = useState("");
11
+ const handleConfirm = () => {
12
+ onConfirm(comment);
13
+ setComment("");
14
+ };
15
+ return /* @__PURE__ */ React.createElement(Dialog, { open, onClose, maxWidth: "sm", fullWidth: true }, /* @__PURE__ */ React.createElement(DialogTitle, null, action === "approve" ? "Approve" : "Reject", " API Key Request"), /* @__PURE__ */ React.createElement(DialogContent, null, request && /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("p", null, /* @__PURE__ */ React.createElement("strong", null, "User:"), " ", request.spec.requestedBy.userId), /* @__PURE__ */ React.createElement("p", null, /* @__PURE__ */ React.createElement("strong", null, "API:"), " ", request.spec.apiName), /* @__PURE__ */ React.createElement("p", null, /* @__PURE__ */ React.createElement("strong", null, "Plan:"), " ", request.spec.planTier), /* @__PURE__ */ React.createElement("p", null, /* @__PURE__ */ React.createElement("strong", null, "Use Case:"), " ", request.spec.useCase || "-"), /* @__PURE__ */ React.createElement(
16
+ TextField,
17
+ {
18
+ label: "Comment (optional)",
19
+ multiline: true,
20
+ rows: 3,
21
+ fullWidth: true,
22
+ margin: "normal",
23
+ value: comment,
24
+ onChange: (e) => setComment(e.target.value)
25
+ }
26
+ ))), /* @__PURE__ */ React.createElement(DialogActions, null, /* @__PURE__ */ React.createElement(Button, { onClick: onClose }, "Cancel"), /* @__PURE__ */ React.createElement(
27
+ Button,
28
+ {
29
+ onClick: handleConfirm,
30
+ color: action === "approve" ? "primary" : "secondary",
31
+ variant: "contained"
32
+ },
33
+ action === "approve" ? "Approve" : "Reject"
34
+ )));
35
+ };
36
+ const ApprovalQueueCard = () => {
37
+ const config = useApi(configApiRef);
38
+ const fetchApi = useApi(fetchApiRef);
39
+ const identityApi = useApi(identityApiRef);
40
+ const backendUrl = config.getString("backend.baseUrl");
41
+ const [refresh, setRefresh] = useState(0);
42
+ const [dialogState, setDialogState] = useState({
43
+ open: false,
44
+ request: null,
45
+ action: "approve"
46
+ });
47
+ const { value, loading, error } = useAsync(async () => {
48
+ const identity = await identityApi.getBackstageIdentity();
49
+ const reviewedBy = identity.userEntityRef;
50
+ console.log("ApprovalQueueCard: fetching all requests from", `${backendUrl}/api/kuadrant/requests`);
51
+ const response = await fetchApi.fetch(
52
+ `${backendUrl}/api/kuadrant/requests`
53
+ );
54
+ if (!response.ok) {
55
+ console.log("ApprovalQueueCard: failed to fetch requests, status:", response.status);
56
+ return { pending: [], approved: [], rejected: [], reviewedBy };
57
+ }
58
+ const contentType = response.headers.get("content-type");
59
+ if (!contentType || !contentType.includes("application/json")) {
60
+ console.log("ApprovalQueueCard: received non-json response");
61
+ return { pending: [], approved: [], rejected: [], reviewedBy };
62
+ }
63
+ const data = await response.json();
64
+ const allRequests = data.items || [];
65
+ console.log("ApprovalQueueCard: received", allRequests.length, "total requests");
66
+ console.log("ApprovalQueueCard: raw requests:", allRequests);
67
+ const pending2 = allRequests.filter((r) => {
68
+ const phase = r.status?.phase || "Pending";
69
+ return phase === "Pending";
70
+ });
71
+ const approved2 = allRequests.filter((r) => {
72
+ const phase = r.status?.phase;
73
+ return phase === "Approved";
74
+ });
75
+ const rejected2 = allRequests.filter((r) => {
76
+ const phase = r.status?.phase;
77
+ return phase === "Rejected";
78
+ });
79
+ console.log("ApprovalQueueCard: grouped -", {
80
+ pending: pending2.length,
81
+ approved: approved2.length,
82
+ rejected: rejected2.length
83
+ });
84
+ return { pending: pending2, approved: approved2, rejected: rejected2, reviewedBy };
85
+ }, [backendUrl, fetchApi, identityApi, refresh]);
86
+ const handleApprove = (request) => {
87
+ setDialogState({ open: true, request, action: "approve" });
88
+ };
89
+ const handleReject = (request) => {
90
+ setDialogState({ open: true, request, action: "reject" });
91
+ };
92
+ const handleConfirm = async (comment) => {
93
+ if (!dialogState.request || !value) return;
94
+ const endpoint = dialogState.action === "approve" ? `${backendUrl}/api/kuadrant/requests/${dialogState.request.metadata.namespace}/${dialogState.request.metadata.name}/approve` : `${backendUrl}/api/kuadrant/requests/${dialogState.request.metadata.namespace}/${dialogState.request.metadata.name}/reject`;
95
+ try {
96
+ const response = await fetchApi.fetch(endpoint, {
97
+ method: "POST",
98
+ headers: { "Content-Type": "application/json" },
99
+ body: JSON.stringify({
100
+ comment,
101
+ reviewedBy: value.reviewedBy
102
+ })
103
+ });
104
+ if (!response.ok) {
105
+ throw new Error(`failed to ${dialogState.action} request`);
106
+ }
107
+ setDialogState({ open: false, request: null, action: "approve" });
108
+ setRefresh((r) => r + 1);
109
+ } catch (err) {
110
+ console.error(`error ${dialogState.action}ing request:`, err);
111
+ }
112
+ };
113
+ if (loading) {
114
+ return /* @__PURE__ */ React.createElement(Progress, null);
115
+ }
116
+ if (error) {
117
+ return /* @__PURE__ */ React.createElement(ResponseErrorPanel, { error });
118
+ }
119
+ const pending = value?.pending || [];
120
+ const approved = value?.approved || [];
121
+ const rejected = value?.rejected || [];
122
+ const formatDate = (dateString) => {
123
+ const date = new Date(dateString);
124
+ return date.toLocaleDateString("en-GB", {
125
+ year: "numeric",
126
+ month: "short",
127
+ day: "numeric",
128
+ hour: "2-digit",
129
+ minute: "2-digit"
130
+ });
131
+ };
132
+ const pendingColumns = [
133
+ {
134
+ title: "Request Name",
135
+ field: "metadata.name",
136
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2" }, row.metadata.name)
137
+ },
138
+ {
139
+ title: "User",
140
+ field: "spec.requestedBy.userId",
141
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2" }, row.spec.requestedBy.userId)
142
+ },
143
+ {
144
+ title: "API",
145
+ field: "spec.apiName",
146
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2" }, /* @__PURE__ */ React.createElement("strong", null, row.spec.apiName))
147
+ },
148
+ {
149
+ title: "Namespace",
150
+ field: "spec.apiNamespace",
151
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2" }, row.spec.apiNamespace)
152
+ },
153
+ {
154
+ title: "Plan",
155
+ field: "spec.planTier",
156
+ render: (row) => /* @__PURE__ */ React.createElement(
157
+ Chip,
158
+ {
159
+ label: row.spec.planTier,
160
+ size: "small"
161
+ }
162
+ )
163
+ },
164
+ {
165
+ title: "Use Case",
166
+ field: "spec.useCase",
167
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2", style: { maxWidth: 200 }, noWrap: true, title: row.spec.useCase }, row.spec.useCase || "-")
168
+ },
169
+ {
170
+ title: "Requested",
171
+ field: "spec.requestedAt",
172
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2" }, row.spec.requestedAt ? formatDate(row.spec.requestedAt) : "-")
173
+ },
174
+ {
175
+ title: "Actions",
176
+ render: (row) => /* @__PURE__ */ React.createElement(Box, { display: "flex", style: { gap: 8 } }, /* @__PURE__ */ React.createElement(
177
+ Button,
178
+ {
179
+ size: "small",
180
+ startIcon: /* @__PURE__ */ React.createElement(CheckCircleIcon, null),
181
+ onClick: () => handleApprove(row),
182
+ color: "primary",
183
+ variant: "outlined"
184
+ },
185
+ "Approve"
186
+ ), /* @__PURE__ */ React.createElement(
187
+ Button,
188
+ {
189
+ size: "small",
190
+ startIcon: /* @__PURE__ */ React.createElement(CancelIcon, null),
191
+ onClick: () => handleReject(row),
192
+ color: "secondary",
193
+ variant: "outlined"
194
+ },
195
+ "Reject"
196
+ ))
197
+ }
198
+ ];
199
+ const approvedColumns = [
200
+ {
201
+ title: "Request Name",
202
+ field: "metadata.name",
203
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2" }, row.metadata.name)
204
+ },
205
+ {
206
+ title: "User",
207
+ field: "spec.requestedBy.userId",
208
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2" }, row.spec.requestedBy.userId)
209
+ },
210
+ {
211
+ title: "API",
212
+ field: "spec.apiName",
213
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2" }, /* @__PURE__ */ React.createElement("strong", null, row.spec.apiName))
214
+ },
215
+ {
216
+ title: "Namespace",
217
+ field: "spec.apiNamespace",
218
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2" }, row.spec.apiNamespace)
219
+ },
220
+ {
221
+ title: "Plan",
222
+ field: "spec.planTier",
223
+ render: (row) => /* @__PURE__ */ React.createElement(
224
+ Chip,
225
+ {
226
+ label: row.spec.planTier,
227
+ size: "small"
228
+ }
229
+ )
230
+ },
231
+ {
232
+ title: "Requested",
233
+ field: "spec.requestedAt",
234
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2" }, row.spec.requestedAt ? formatDate(row.spec.requestedAt) : "-")
235
+ },
236
+ {
237
+ title: "Approved",
238
+ field: "status.reviewedAt",
239
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2" }, row.status?.reviewedAt ? formatDate(row.status.reviewedAt) : "-")
240
+ },
241
+ {
242
+ title: "Reviewed By",
243
+ field: "status.reviewedBy",
244
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2" }, row.status?.reviewedBy || "-")
245
+ },
246
+ {
247
+ title: "Approval Type",
248
+ field: "status.reviewedBy",
249
+ render: (row) => {
250
+ const isAutomatic = row.status?.reviewedBy === "system";
251
+ return /* @__PURE__ */ React.createElement(
252
+ Chip,
253
+ {
254
+ label: isAutomatic ? "Automatic" : "Manual",
255
+ size: "small",
256
+ color: isAutomatic ? "default" : "primary"
257
+ }
258
+ );
259
+ }
260
+ }
261
+ ];
262
+ const rejectedColumns = [
263
+ {
264
+ title: "Request Name",
265
+ field: "metadata.name",
266
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2" }, row.metadata.name)
267
+ },
268
+ {
269
+ title: "User",
270
+ field: "spec.requestedBy.userId",
271
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2" }, row.spec.requestedBy.userId)
272
+ },
273
+ {
274
+ title: "API",
275
+ field: "spec.apiName",
276
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2" }, /* @__PURE__ */ React.createElement("strong", null, row.spec.apiName))
277
+ },
278
+ {
279
+ title: "Namespace",
280
+ field: "spec.apiNamespace",
281
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2" }, row.spec.apiNamespace)
282
+ },
283
+ {
284
+ title: "Plan",
285
+ field: "spec.planTier",
286
+ render: (row) => /* @__PURE__ */ React.createElement(
287
+ Chip,
288
+ {
289
+ label: row.spec.planTier,
290
+ size: "small"
291
+ }
292
+ )
293
+ },
294
+ {
295
+ title: "Requested",
296
+ field: "spec.requestedAt",
297
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2" }, row.spec.requestedAt ? formatDate(row.spec.requestedAt) : "-")
298
+ },
299
+ {
300
+ title: "Rejected",
301
+ field: "status.reviewedAt",
302
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2" }, row.status?.reviewedAt ? formatDate(row.status.reviewedAt) : "-")
303
+ },
304
+ {
305
+ title: "Reviewed By",
306
+ field: "status.reviewedBy",
307
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2" }, row.status?.reviewedBy || "-")
308
+ },
309
+ {
310
+ title: "Reason",
311
+ field: "status.comment",
312
+ render: (row) => /* @__PURE__ */ React.createElement(Typography, { variant: "body2", style: { maxWidth: 200 }, noWrap: true, title: row.status?.comment }, row.status?.comment || "-")
313
+ }
314
+ ];
315
+ return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(Box, null, /* @__PURE__ */ React.createElement(InfoCard, { title: `Pending Requests (${pending.length})` }, pending.length === 0 ? /* @__PURE__ */ React.createElement(Typography, { variant: "body2", color: "textSecondary" }, "No pending requests") : /* @__PURE__ */ React.createElement(
316
+ Table,
317
+ {
318
+ options: { paging: true, pageSize: 5, search: false, toolbar: false },
319
+ data: pending,
320
+ columns: pendingColumns
321
+ }
322
+ )), approved.length > 0 && /* @__PURE__ */ React.createElement(Box, { mt: 3 }, /* @__PURE__ */ React.createElement(InfoCard, { title: `Approved Requests (${approved.length})` }, /* @__PURE__ */ React.createElement(
323
+ Table,
324
+ {
325
+ options: { paging: true, pageSize: 5, search: false, toolbar: false },
326
+ data: approved,
327
+ columns: approvedColumns
328
+ }
329
+ ))), rejected.length > 0 && /* @__PURE__ */ React.createElement(Box, { mt: 3 }, /* @__PURE__ */ React.createElement(InfoCard, { title: `Rejected Requests (${rejected.length})` }, /* @__PURE__ */ React.createElement(
330
+ Table,
331
+ {
332
+ options: { paging: true, pageSize: 5, search: false, toolbar: false },
333
+ data: rejected,
334
+ columns: rejectedColumns
335
+ }
336
+ )))), /* @__PURE__ */ React.createElement(
337
+ ApprovalDialog,
338
+ {
339
+ open: dialogState.open,
340
+ request: dialogState.request,
341
+ action: dialogState.action,
342
+ onClose: () => setDialogState({ open: false, request: null, action: "approve" }),
343
+ onConfirm: handleConfirm
344
+ }
345
+ ));
346
+ };
347
+
348
+ export { ApprovalQueueCard };
349
+ //# sourceMappingURL=ApprovalQueueCard.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ApprovalQueueCard.esm.js","sources":["../../../src/components/ApprovalQueueCard/ApprovalQueueCard.tsx"],"sourcesContent":["import React, { useState } from 'react';\nimport { useApi, fetchApiRef, identityApiRef, configApiRef } from '@backstage/core-plugin-api';\nimport { useAsync } from 'react-use';\nimport {\n Table,\n TableColumn,\n Progress,\n ResponseErrorPanel,\n InfoCard,\n} from '@backstage/core-components';\nimport {\n Button,\n Dialog,\n DialogTitle,\n DialogContent,\n DialogActions,\n TextField,\n Chip,\n Typography,\n Box,\n} from '@material-ui/core';\nimport CheckCircleIcon from '@material-ui/icons/CheckCircle';\nimport CancelIcon from '@material-ui/icons/Cancel';\nimport { APIKeyRequest } from '../../types/api-management';\n\ninterface ApprovalDialogProps {\n open: boolean;\n request: APIKeyRequest | null;\n action: 'approve' | 'reject';\n onClose: () => void;\n onConfirm: (comment: string) => void;\n}\n\nconst ApprovalDialog = ({ open, request, action, onClose, onConfirm }: ApprovalDialogProps) => {\n const [comment, setComment] = useState('');\n\n const handleConfirm = () => {\n onConfirm(comment);\n setComment('');\n };\n\n return (\n <Dialog open={open} onClose={onClose} maxWidth=\"sm\" fullWidth>\n <DialogTitle>\n {action === 'approve' ? 'Approve' : 'Reject'} API Key Request\n </DialogTitle>\n <DialogContent>\n {request && (\n <>\n <p><strong>User:</strong> {request.spec.requestedBy.userId}</p>\n <p><strong>API:</strong> {request.spec.apiName}</p>\n <p><strong>Plan:</strong> {request.spec.planTier}</p>\n <p><strong>Use Case:</strong> {request.spec.useCase || '-'}</p>\n <TextField\n label=\"Comment (optional)\"\n multiline\n rows={3}\n fullWidth\n margin=\"normal\"\n value={comment}\n onChange={(e) => setComment(e.target.value)}\n />\n </>\n )}\n </DialogContent>\n <DialogActions>\n <Button onClick={onClose}>Cancel</Button>\n <Button\n onClick={handleConfirm}\n color={action === 'approve' ? 'primary' : 'secondary'}\n variant=\"contained\"\n >\n {action === 'approve' ? 'Approve' : 'Reject'}\n </Button>\n </DialogActions>\n </Dialog>\n );\n};\n\nexport const ApprovalQueueCard = () => {\n const config = useApi(configApiRef);\n const fetchApi = useApi(fetchApiRef);\n const identityApi = useApi(identityApiRef);\n const backendUrl = config.getString('backend.baseUrl');\n const [refresh, setRefresh] = useState(0);\n const [dialogState, setDialogState] = useState<{\n open: boolean;\n request: APIKeyRequest | null;\n action: 'approve' | 'reject';\n }>({\n open: false,\n request: null,\n action: 'approve',\n });\n\n const { value, loading, error } = useAsync(async () => {\n const identity = await identityApi.getBackstageIdentity();\n const reviewedBy = identity.userEntityRef;\n\n console.log('ApprovalQueueCard: fetching all requests from', `${backendUrl}/api/kuadrant/requests`);\n\n const response = await fetchApi.fetch(\n `${backendUrl}/api/kuadrant/requests`\n );\n if (!response.ok) {\n console.log('ApprovalQueueCard: failed to fetch requests, status:', response.status);\n return { pending: [], approved: [], rejected: [], reviewedBy };\n }\n\n // check content-type before parsing json\n const contentType = response.headers.get('content-type');\n if (!contentType || !contentType.includes('application/json')) {\n console.log('ApprovalQueueCard: received non-json response');\n return { pending: [], approved: [], rejected: [], reviewedBy };\n }\n\n const data = await response.json();\n const allRequests = data.items || [];\n\n console.log('ApprovalQueueCard: received', allRequests.length, 'total requests');\n console.log('ApprovalQueueCard: raw requests:', allRequests);\n\n // group by status (field is 'phase' not 'status')\n const pending = allRequests.filter((r: APIKeyRequest) => {\n const phase = (r.status as any)?.phase || 'Pending';\n return phase === 'Pending';\n });\n const approved = allRequests.filter((r: APIKeyRequest) => {\n const phase = (r.status as any)?.phase;\n return phase === 'Approved';\n });\n const rejected = allRequests.filter((r: APIKeyRequest) => {\n const phase = (r.status as any)?.phase;\n return phase === 'Rejected';\n });\n\n console.log('ApprovalQueueCard: grouped -', {\n pending: pending.length,\n approved: approved.length,\n rejected: rejected.length,\n });\n\n return { pending, approved, rejected, reviewedBy };\n }, [backendUrl, fetchApi, identityApi, refresh]);\n\n const handleApprove = (request: APIKeyRequest) => {\n setDialogState({ open: true, request, action: 'approve' });\n };\n\n const handleReject = (request: APIKeyRequest) => {\n setDialogState({ open: true, request, action: 'reject' });\n };\n\n const handleConfirm = async (comment: string) => {\n if (!dialogState.request || !value) return;\n\n const endpoint = dialogState.action === 'approve'\n ? `${backendUrl}/api/kuadrant/requests/${dialogState.request.metadata.namespace}/${dialogState.request.metadata.name}/approve`\n : `${backendUrl}/api/kuadrant/requests/${dialogState.request.metadata.namespace}/${dialogState.request.metadata.name}/reject`;\n\n try {\n const response = await fetchApi.fetch(endpoint, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({\n comment,\n reviewedBy: value.reviewedBy,\n }),\n });\n\n if (!response.ok) {\n throw new Error(`failed to ${dialogState.action} request`);\n }\n\n setDialogState({ open: false, request: null, action: 'approve' });\n setRefresh(r => r + 1);\n } catch (err) {\n console.error(`error ${dialogState.action}ing request:`, err);\n }\n };\n\n if (loading) {\n return <Progress />;\n }\n\n if (error) {\n return <ResponseErrorPanel error={error} />;\n }\n\n const pending = value?.pending || [];\n const approved = value?.approved || [];\n const rejected = value?.rejected || [];\n\n const formatDate = (dateString: string) => {\n const date = new Date(dateString);\n return date.toLocaleDateString('en-GB', {\n year: 'numeric',\n month: 'short',\n day: 'numeric',\n hour: '2-digit',\n minute: '2-digit',\n });\n };\n\n const pendingColumns: TableColumn<APIKeyRequest>[] = [\n {\n title: 'Request Name',\n field: 'metadata.name',\n render: (row) => <Typography variant=\"body2\">{row.metadata.name}</Typography>,\n },\n {\n title: 'User',\n field: 'spec.requestedBy.userId',\n render: (row) => <Typography variant=\"body2\">{row.spec.requestedBy.userId}</Typography>,\n },\n {\n title: 'API',\n field: 'spec.apiName',\n render: (row) => <Typography variant=\"body2\"><strong>{row.spec.apiName}</strong></Typography>,\n },\n {\n title: 'Namespace',\n field: 'spec.apiNamespace',\n render: (row) => <Typography variant=\"body2\">{row.spec.apiNamespace}</Typography>,\n },\n {\n title: 'Plan',\n field: 'spec.planTier',\n render: (row) => (\n <Chip\n label={row.spec.planTier}\n size=\"small\"\n />\n ),\n },\n {\n title: 'Use Case',\n field: 'spec.useCase',\n render: (row) => (\n <Typography variant=\"body2\" style={{ maxWidth: 200 }} noWrap title={row.spec.useCase}>\n {row.spec.useCase || '-'}\n </Typography>\n ),\n },\n {\n title: 'Requested',\n field: 'spec.requestedAt',\n render: (row) => (\n <Typography variant=\"body2\">\n {row.spec.requestedAt ? formatDate(row.spec.requestedAt) : '-'}\n </Typography>\n ),\n },\n {\n title: 'Actions',\n render: (row) => (\n <Box display=\"flex\" style={{ gap: 8 }}>\n <Button\n size=\"small\"\n startIcon={<CheckCircleIcon />}\n onClick={() => handleApprove(row)}\n color=\"primary\"\n variant=\"outlined\"\n >\n Approve\n </Button>\n <Button\n size=\"small\"\n startIcon={<CancelIcon />}\n onClick={() => handleReject(row)}\n color=\"secondary\"\n variant=\"outlined\"\n >\n Reject\n </Button>\n </Box>\n ),\n },\n ];\n\n const approvedColumns: TableColumn<APIKeyRequest>[] = [\n {\n title: 'Request Name',\n field: 'metadata.name',\n render: (row) => <Typography variant=\"body2\">{row.metadata.name}</Typography>,\n },\n {\n title: 'User',\n field: 'spec.requestedBy.userId',\n render: (row) => <Typography variant=\"body2\">{row.spec.requestedBy.userId}</Typography>,\n },\n {\n title: 'API',\n field: 'spec.apiName',\n render: (row) => <Typography variant=\"body2\"><strong>{row.spec.apiName}</strong></Typography>,\n },\n {\n title: 'Namespace',\n field: 'spec.apiNamespace',\n render: (row) => <Typography variant=\"body2\">{row.spec.apiNamespace}</Typography>,\n },\n {\n title: 'Plan',\n field: 'spec.planTier',\n render: (row) => (\n <Chip\n label={row.spec.planTier}\n size=\"small\"\n />\n ),\n },\n {\n title: 'Requested',\n field: 'spec.requestedAt',\n render: (row) => (\n <Typography variant=\"body2\">\n {row.spec.requestedAt ? formatDate(row.spec.requestedAt) : '-'}\n </Typography>\n ),\n },\n {\n title: 'Approved',\n field: 'status.reviewedAt',\n render: (row) => (\n <Typography variant=\"body2\">\n {row.status?.reviewedAt ? formatDate(row.status.reviewedAt) : '-'}\n </Typography>\n ),\n },\n {\n title: 'Reviewed By',\n field: 'status.reviewedBy',\n render: (row) => (\n <Typography variant=\"body2\">\n {row.status?.reviewedBy || '-'}\n </Typography>\n ),\n },\n {\n title: 'Approval Type',\n field: 'status.reviewedBy',\n render: (row) => {\n const isAutomatic = row.status?.reviewedBy === 'system';\n return (\n <Chip\n label={isAutomatic ? 'Automatic' : 'Manual'}\n size=\"small\"\n color={isAutomatic ? 'default' : 'primary'}\n />\n );\n },\n },\n ];\n\n const rejectedColumns: TableColumn<APIKeyRequest>[] = [\n {\n title: 'Request Name',\n field: 'metadata.name',\n render: (row) => <Typography variant=\"body2\">{row.metadata.name}</Typography>,\n },\n {\n title: 'User',\n field: 'spec.requestedBy.userId',\n render: (row) => <Typography variant=\"body2\">{row.spec.requestedBy.userId}</Typography>,\n },\n {\n title: 'API',\n field: 'spec.apiName',\n render: (row) => <Typography variant=\"body2\"><strong>{row.spec.apiName}</strong></Typography>,\n },\n {\n title: 'Namespace',\n field: 'spec.apiNamespace',\n render: (row) => <Typography variant=\"body2\">{row.spec.apiNamespace}</Typography>,\n },\n {\n title: 'Plan',\n field: 'spec.planTier',\n render: (row) => (\n <Chip\n label={row.spec.planTier}\n size=\"small\"\n />\n ),\n },\n {\n title: 'Requested',\n field: 'spec.requestedAt',\n render: (row) => (\n <Typography variant=\"body2\">\n {row.spec.requestedAt ? formatDate(row.spec.requestedAt) : '-'}\n </Typography>\n ),\n },\n {\n title: 'Rejected',\n field: 'status.reviewedAt',\n render: (row) => (\n <Typography variant=\"body2\">\n {row.status?.reviewedAt ? formatDate(row.status.reviewedAt) : '-'}\n </Typography>\n ),\n },\n {\n title: 'Reviewed By',\n field: 'status.reviewedBy',\n render: (row) => (\n <Typography variant=\"body2\">\n {row.status?.reviewedBy || '-'}\n </Typography>\n ),\n },\n {\n title: 'Reason',\n field: 'status.comment',\n render: (row) => (\n <Typography variant=\"body2\" style={{ maxWidth: 200 }} noWrap title={row.status?.comment}>\n {row.status?.comment || '-'}\n </Typography>\n ),\n },\n ];\n\n return (\n <>\n <Box>\n <InfoCard title={`Pending Requests (${pending.length})`}>\n {pending.length === 0 ? (\n <Typography variant=\"body2\" color=\"textSecondary\">No pending requests</Typography>\n ) : (\n <Table\n options={{ paging: true, pageSize: 5, search: false, toolbar: false }}\n data={pending}\n columns={pendingColumns}\n />\n )}\n </InfoCard>\n\n {approved.length > 0 && (\n <Box mt={3}>\n <InfoCard title={`Approved Requests (${approved.length})`}>\n <Table\n options={{ paging: true, pageSize: 5, search: false, toolbar: false }}\n data={approved}\n columns={approvedColumns}\n />\n </InfoCard>\n </Box>\n )}\n\n {rejected.length > 0 && (\n <Box mt={3}>\n <InfoCard title={`Rejected Requests (${rejected.length})`}>\n <Table\n options={{ paging: true, pageSize: 5, search: false, toolbar: false }}\n data={rejected}\n columns={rejectedColumns}\n />\n </InfoCard>\n </Box>\n )}\n </Box>\n <ApprovalDialog\n open={dialogState.open}\n request={dialogState.request}\n action={dialogState.action}\n onClose={() => setDialogState({ open: false, request: null, action: 'approve' })}\n onConfirm={handleConfirm}\n />\n </>\n );\n};\n"],"names":["pending","approved","rejected"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export { ApprovalQueueCard } from './ApprovalQueueCard.esm.js';
2
+ //# sourceMappingURL=index.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.esm.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}