@backstage/plugin-kubernetes-react 0.3.4-next.1 → 0.3.5-next.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 (154) hide show
  1. package/CHANGELOG.md +27 -0
  2. package/dist/api/KubernetesBackendClient.esm.js +137 -0
  3. package/dist/api/KubernetesBackendClient.esm.js.map +1 -0
  4. package/dist/api/KubernetesClusterLinkFormatter.esm.js +38 -0
  5. package/dist/api/KubernetesClusterLinkFormatter.esm.js.map +1 -0
  6. package/dist/api/KubernetesProxyClient.esm.js +76 -0
  7. package/dist/api/KubernetesProxyClient.esm.js.map +1 -0
  8. package/dist/api/formatters/AksClusterLinksFormatter.esm.js +35 -0
  9. package/dist/api/formatters/AksClusterLinksFormatter.esm.js.map +1 -0
  10. package/dist/api/formatters/EksClusterLinksFormatter.esm.js +10 -0
  11. package/dist/api/formatters/EksClusterLinksFormatter.esm.js.map +1 -0
  12. package/dist/api/formatters/GkeClusterLinksFormatter.esm.js +62 -0
  13. package/dist/api/formatters/GkeClusterLinksFormatter.esm.js.map +1 -0
  14. package/dist/api/formatters/OpenshiftClusterLinksFormatter.esm.js +41 -0
  15. package/dist/api/formatters/OpenshiftClusterLinksFormatter.esm.js.map +1 -0
  16. package/dist/api/formatters/RancherClusterLinksFormatter.esm.js +33 -0
  17. package/dist/api/formatters/RancherClusterLinksFormatter.esm.js.map +1 -0
  18. package/dist/api/formatters/StandardClusterLinksFormatter.esm.js +37 -0
  19. package/dist/api/formatters/StandardClusterLinksFormatter.esm.js.map +1 -0
  20. package/dist/api/formatters/index.esm.js +21 -0
  21. package/dist/api/formatters/index.esm.js.map +1 -0
  22. package/dist/api/types.esm.js +14 -0
  23. package/dist/api/types.esm.js.map +1 -0
  24. package/dist/components/Cluster/Cluster.esm.js +88 -0
  25. package/dist/components/Cluster/Cluster.esm.js.map +1 -0
  26. package/dist/components/CronJobsAccordions/CronJobsAccordions.esm.js +80 -0
  27. package/dist/components/CronJobsAccordions/CronJobsAccordions.esm.js.map +1 -0
  28. package/dist/components/CronJobsAccordions/CronJobsDrawer.esm.js +51 -0
  29. package/dist/components/CronJobsAccordions/CronJobsDrawer.esm.js.map +1 -0
  30. package/dist/components/CustomResources/ArgoRollouts/Rollout.esm.js +222 -0
  31. package/dist/components/CustomResources/ArgoRollouts/Rollout.esm.js.map +1 -0
  32. package/dist/components/CustomResources/ArgoRollouts/RolloutDrawer.esm.js +40 -0
  33. package/dist/components/CustomResources/ArgoRollouts/RolloutDrawer.esm.js.map +1 -0
  34. package/dist/components/CustomResources/ArgoRollouts/StepsProgress.esm.js +32 -0
  35. package/dist/components/CustomResources/ArgoRollouts/StepsProgress.esm.js.map +1 -0
  36. package/dist/components/CustomResources/CustomResources.esm.js +44 -0
  37. package/dist/components/CustomResources/CustomResources.esm.js.map +1 -0
  38. package/dist/components/CustomResources/DefaultCustomResource.esm.js +79 -0
  39. package/dist/components/CustomResources/DefaultCustomResource.esm.js.map +1 -0
  40. package/dist/components/CustomResources/DefaultCustomResourceDrawer.esm.js +43 -0
  41. package/dist/components/CustomResources/DefaultCustomResourceDrawer.esm.js.map +1 -0
  42. package/dist/components/DaemonSetsAccordions/DaemonSetsAccordions.esm.js +126 -0
  43. package/dist/components/DaemonSetsAccordions/DaemonSetsAccordions.esm.js.map +1 -0
  44. package/dist/components/DaemonSetsAccordions/DaemonSetsDrawer.esm.js +55 -0
  45. package/dist/components/DaemonSetsAccordions/DaemonSetsDrawer.esm.js.map +1 -0
  46. package/dist/components/DeploymentsAccordions/DeploymentDrawer.esm.js +56 -0
  47. package/dist/components/DeploymentsAccordions/DeploymentDrawer.esm.js.map +1 -0
  48. package/dist/components/DeploymentsAccordions/DeploymentsAccordions.esm.js +160 -0
  49. package/dist/components/DeploymentsAccordions/DeploymentsAccordions.esm.js.map +1 -0
  50. package/dist/components/ErrorPanel/ErrorPanel.esm.js +27 -0
  51. package/dist/components/ErrorPanel/ErrorPanel.esm.js.map +1 -0
  52. package/dist/components/ErrorReporting/ErrorReporting.esm.js +63 -0
  53. package/dist/components/ErrorReporting/ErrorReporting.esm.js.map +1 -0
  54. package/dist/components/HorizontalPodAutoscalers/HorizontalPodAutoscalerDrawer.esm.js +34 -0
  55. package/dist/components/HorizontalPodAutoscalers/HorizontalPodAutoscalerDrawer.esm.js.map +1 -0
  56. package/dist/components/IngressesAccordions/IngressDrawer.esm.js +42 -0
  57. package/dist/components/IngressesAccordions/IngressDrawer.esm.js.map +1 -0
  58. package/dist/components/IngressesAccordions/IngressesAccordions.esm.js +62 -0
  59. package/dist/components/IngressesAccordions/IngressesAccordions.esm.js.map +1 -0
  60. package/dist/components/JobsAccordions/JobsAccordions.esm.js +101 -0
  61. package/dist/components/JobsAccordions/JobsAccordions.esm.js.map +1 -0
  62. package/dist/components/JobsAccordions/JobsDrawer.esm.js +48 -0
  63. package/dist/components/JobsAccordions/JobsDrawer.esm.js.map +1 -0
  64. package/dist/components/KubernetesDialog/KubernetesDialog.esm.js +72 -0
  65. package/dist/components/KubernetesDialog/KubernetesDialog.esm.js.map +1 -0
  66. package/dist/components/KubernetesDrawer/KubernetesDrawer.esm.js +117 -0
  67. package/dist/components/KubernetesDrawer/KubernetesDrawer.esm.js.map +1 -0
  68. package/dist/components/KubernetesDrawer/KubernetesStructuredMetadataTableDrawer.esm.js +199 -0
  69. package/dist/components/KubernetesDrawer/KubernetesStructuredMetadataTableDrawer.esm.js.map +1 -0
  70. package/dist/components/KubernetesDrawer/ManifestYaml.esm.js +44 -0
  71. package/dist/components/KubernetesDrawer/ManifestYaml.esm.js.map +1 -0
  72. package/dist/components/PodExecTerminal/PodExecTerminal.esm.js +88 -0
  73. package/dist/components/PodExecTerminal/PodExecTerminal.esm.js.map +1 -0
  74. package/dist/components/PodExecTerminal/PodExecTerminalAttachAddon.esm.js +40 -0
  75. package/dist/components/PodExecTerminal/PodExecTerminalAttachAddon.esm.js.map +1 -0
  76. package/dist/components/PodExecTerminal/PodExecTerminalDialog.esm.js +35 -0
  77. package/dist/components/PodExecTerminal/PodExecTerminalDialog.esm.js.map +1 -0
  78. package/dist/components/Pods/ErrorList/ErrorList.esm.js +52 -0
  79. package/dist/components/Pods/ErrorList/ErrorList.esm.js.map +1 -0
  80. package/dist/components/Pods/Events/Events.esm.js +74 -0
  81. package/dist/components/Pods/Events/Events.esm.js.map +1 -0
  82. package/dist/components/Pods/Events/useEvents.esm.js +21 -0
  83. package/dist/components/Pods/Events/useEvents.esm.js.map +1 -0
  84. package/dist/components/Pods/FixDialog/FixDialog.esm.js +107 -0
  85. package/dist/components/Pods/FixDialog/FixDialog.esm.js.map +1 -0
  86. package/dist/components/Pods/PodDrawer/ContainerCard.esm.js +166 -0
  87. package/dist/components/Pods/PodDrawer/ContainerCard.esm.js.map +1 -0
  88. package/dist/components/Pods/PodDrawer/PendingPodContent.esm.js +30 -0
  89. package/dist/components/Pods/PodDrawer/PendingPodContent.esm.js.map +1 -0
  90. package/dist/components/Pods/PodDrawer/PodDrawer.esm.js +114 -0
  91. package/dist/components/Pods/PodDrawer/PodDrawer.esm.js.map +1 -0
  92. package/dist/components/Pods/PodLogs/PodLogs.esm.js +44 -0
  93. package/dist/components/Pods/PodLogs/PodLogs.esm.js.map +1 -0
  94. package/dist/components/Pods/PodLogs/PodLogsDialog.esm.js +21 -0
  95. package/dist/components/Pods/PodLogs/PodLogsDialog.esm.js.map +1 -0
  96. package/dist/components/Pods/PodLogs/usePodLogs.esm.js +19 -0
  97. package/dist/components/Pods/PodLogs/usePodLogs.esm.js.map +1 -0
  98. package/dist/components/Pods/PodsTable.esm.js +153 -0
  99. package/dist/components/Pods/PodsTable.esm.js.map +1 -0
  100. package/dist/components/ResourceUtilization/ResourceUtilization.esm.js +50 -0
  101. package/dist/components/ResourceUtilization/ResourceUtilization.esm.js.map +1 -0
  102. package/dist/components/ServicesAccordions/ServiceDrawer.esm.js +42 -0
  103. package/dist/components/ServicesAccordions/ServiceDrawer.esm.js.map +1 -0
  104. package/dist/components/ServicesAccordions/ServicesAccordions.esm.js +79 -0
  105. package/dist/components/ServicesAccordions/ServicesAccordions.esm.js.map +1 -0
  106. package/dist/components/StatefulSetsAccordions/StatefulSetDrawer.esm.js +58 -0
  107. package/dist/components/StatefulSetsAccordions/StatefulSetDrawer.esm.js.map +1 -0
  108. package/dist/components/StatefulSetsAccordions/StatefulSetsAccordions.esm.js +156 -0
  109. package/dist/components/StatefulSetsAccordions/StatefulSetsAccordions.esm.js.map +1 -0
  110. package/dist/hooks/Cluster.esm.js +8 -0
  111. package/dist/hooks/Cluster.esm.js.map +1 -0
  112. package/dist/hooks/GroupedResponses.esm.js +19 -0
  113. package/dist/hooks/GroupedResponses.esm.js.map +1 -0
  114. package/dist/hooks/PodNamesWithErrors.esm.js +8 -0
  115. package/dist/hooks/PodNamesWithErrors.esm.js.map +1 -0
  116. package/dist/hooks/PodNamesWithMetrics.esm.js +6 -0
  117. package/dist/hooks/PodNamesWithMetrics.esm.js.map +1 -0
  118. package/dist/hooks/auth.esm.js +24 -0
  119. package/dist/hooks/auth.esm.js.map +1 -0
  120. package/dist/hooks/useCustomResources.esm.js +42 -0
  121. package/dist/hooks/useCustomResources.esm.js.map +1 -0
  122. package/dist/hooks/useIsPodExecTerminalEnabled.esm.js +9 -0
  123. package/dist/hooks/useIsPodExecTerminalEnabled.esm.js.map +1 -0
  124. package/dist/hooks/useIsPodExecTerminalSupported.esm.js +21 -0
  125. package/dist/hooks/useIsPodExecTerminalSupported.esm.js.map +1 -0
  126. package/dist/hooks/useKubernetesObjects.esm.js +36 -0
  127. package/dist/hooks/useKubernetesObjects.esm.js.map +1 -0
  128. package/dist/hooks/useMatchingErrors.esm.js +20 -0
  129. package/dist/hooks/useMatchingErrors.esm.js.map +1 -0
  130. package/dist/hooks/usePodMetrics.esm.js +20 -0
  131. package/dist/hooks/usePodMetrics.esm.js.map +1 -0
  132. package/dist/index.esm.js +53 -3441
  133. package/dist/index.esm.js.map +1 -1
  134. package/dist/kubernetes-auth-provider/AksKubernetesAuthProvider.esm.js +21 -0
  135. package/dist/kubernetes-auth-provider/AksKubernetesAuthProvider.esm.js.map +1 -0
  136. package/dist/kubernetes-auth-provider/GoogleKubernetesAuthProvider.esm.js +31 -0
  137. package/dist/kubernetes-auth-provider/GoogleKubernetesAuthProvider.esm.js.map +1 -0
  138. package/dist/kubernetes-auth-provider/KubernetesAuthProviders.esm.js +89 -0
  139. package/dist/kubernetes-auth-provider/KubernetesAuthProviders.esm.js.map +1 -0
  140. package/dist/kubernetes-auth-provider/OidcKubernetesAuthProvider.esm.js +33 -0
  141. package/dist/kubernetes-auth-provider/OidcKubernetesAuthProvider.esm.js.map +1 -0
  142. package/dist/kubernetes-auth-provider/ServerSideAuthProvider.esm.js +11 -0
  143. package/dist/kubernetes-auth-provider/ServerSideAuthProvider.esm.js.map +1 -0
  144. package/dist/kubernetes-auth-provider/types.esm.js +8 -0
  145. package/dist/kubernetes-auth-provider/types.esm.js.map +1 -0
  146. package/dist/utils/crons.esm.js +22 -0
  147. package/dist/utils/crons.esm.js.map +1 -0
  148. package/dist/utils/owner.esm.js +30 -0
  149. package/dist/utils/owner.esm.js.map +1 -0
  150. package/dist/utils/pod.esm.js +120 -0
  151. package/dist/utils/pod.esm.js.map +1 -0
  152. package/dist/utils/resources.esm.js +19 -0
  153. package/dist/utils/resources.esm.js.map +1 -0
  154. package/package.json +9 -9
@@ -0,0 +1,48 @@
1
+ import React__default from 'react';
2
+ import { KubernetesStructuredMetadataTableDrawer } from '../KubernetesDrawer/KubernetesStructuredMetadataTableDrawer.esm.js';
3
+ import '../KubernetesDrawer/KubernetesDrawer.esm.js';
4
+ import '@backstage/core-components';
5
+ import '@material-ui/core/FormControlLabel';
6
+ import '@material-ui/core/Switch';
7
+ import 'js-yaml';
8
+ import Typography from '@material-ui/core/Typography';
9
+ import Grid from '@material-ui/core/Grid';
10
+
11
+ const JobDrawer = ({
12
+ job,
13
+ expanded
14
+ }) => {
15
+ var _a, _b;
16
+ return /* @__PURE__ */ React__default.createElement(
17
+ KubernetesStructuredMetadataTableDrawer,
18
+ {
19
+ object: job,
20
+ expanded,
21
+ kind: "Job",
22
+ renderObject: (jobObj) => {
23
+ var _a2, _b2, _c, _d, _e, _f, _g, _h;
24
+ return {
25
+ parallelism: (_b2 = (_a2 = jobObj.spec) == null ? void 0 : _a2.parallelism) != null ? _b2 : "???",
26
+ completions: (_d = (_c = jobObj.spec) == null ? void 0 : _c.completions) != null ? _d : "???",
27
+ backoffLimit: (_f = (_e = jobObj.spec) == null ? void 0 : _e.backoffLimit) != null ? _f : "???",
28
+ startTime: (_h = (_g = jobObj.status) == null ? void 0 : _g.startTime) != null ? _h : "???"
29
+ };
30
+ }
31
+ },
32
+ /* @__PURE__ */ React__default.createElement(
33
+ Grid,
34
+ {
35
+ container: true,
36
+ direction: "column",
37
+ justifyContent: "flex-start",
38
+ alignItems: "flex-start",
39
+ spacing: 0
40
+ },
41
+ /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(Typography, { variant: "body1" }, (_b = (_a = job.metadata) == null ? void 0 : _a.name) != null ? _b : "unknown object")),
42
+ /* @__PURE__ */ React__default.createElement(Grid, { item: true }, /* @__PURE__ */ React__default.createElement(Typography, { color: "textSecondary", variant: "subtitle1" }, "Job"))
43
+ )
44
+ );
45
+ };
46
+
47
+ export { JobDrawer };
48
+ //# sourceMappingURL=JobsDrawer.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JobsDrawer.esm.js","sources":["../../../src/components/JobsAccordions/JobsDrawer.tsx"],"sourcesContent":["/*\n * Copyright 2021 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 React from 'react';\nimport { V1Job } from '@kubernetes/client-node';\nimport { KubernetesStructuredMetadataTableDrawer } from '../KubernetesDrawer';\nimport Typography from '@material-ui/core/Typography';\nimport Grid from '@material-ui/core/Grid';\n\nexport const JobDrawer = ({\n job,\n expanded,\n}: {\n job: V1Job;\n expanded?: boolean;\n}) => {\n return (\n <KubernetesStructuredMetadataTableDrawer\n object={job}\n expanded={expanded}\n kind=\"Job\"\n renderObject={(jobObj: V1Job) => {\n return {\n parallelism: jobObj.spec?.parallelism ?? '???',\n completions: jobObj.spec?.completions ?? '???',\n backoffLimit: jobObj.spec?.backoffLimit ?? '???',\n startTime: jobObj.status?.startTime ?? '???',\n };\n }}\n >\n <Grid\n container\n direction=\"column\"\n justifyContent=\"flex-start\"\n alignItems=\"flex-start\"\n spacing={0}\n >\n <Grid item>\n <Typography variant=\"body1\">\n {job.metadata?.name ?? 'unknown object'}\n </Typography>\n </Grid>\n <Grid item>\n <Typography color=\"textSecondary\" variant=\"subtitle1\">\n Job\n </Typography>\n </Grid>\n </Grid>\n </KubernetesStructuredMetadataTableDrawer>\n );\n};\n"],"names":["React","_a","_b"],"mappings":";;;;;;;;;;AAqBO,MAAM,YAAY,CAAC;AAAA,EACxB,GAAA;AAAA,EACA,QAAA;AACF,CAGM,KAAA;AA3BN,EAAA,IAAA,EAAA,EAAA,EAAA,CAAA;AA4BE,EACE,uBAAAA,cAAA,CAAA,aAAA;AAAA,IAAC,uCAAA;AAAA,IAAA;AAAA,MACC,MAAQ,EAAA,GAAA;AAAA,MACR,QAAA;AAAA,MACA,IAAK,EAAA,KAAA;AAAA,MACL,YAAA,EAAc,CAAC,MAAkB,KAAA;AAjCvC,QAAA,IAAAC,KAAAC,GAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,CAAA;AAkCQ,QAAO,OAAA;AAAA,UACL,WAAA,EAAA,CAAaA,OAAAD,GAAA,GAAA,MAAA,CAAO,SAAP,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,GAAAA,CAAa,WAAb,KAAA,IAAA,GAAAC,GAA4B,GAAA,KAAA;AAAA,UACzC,WAAa,EAAA,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,MAAA,CAAO,IAAP,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAa,gBAAb,IAA4B,GAAA,EAAA,GAAA,KAAA;AAAA,UACzC,YAAc,EAAA,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,MAAA,CAAO,IAAP,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAa,iBAAb,IAA6B,GAAA,EAAA,GAAA,KAAA;AAAA,UAC3C,SAAW,EAAA,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,MAAA,CAAO,MAAP,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAe,cAAf,IAA4B,GAAA,EAAA,GAAA,KAAA;AAAA,SACzC,CAAA;AAAA,OACF;AAAA,KAAA;AAAA,oBAEAF,cAAA,CAAA,aAAA;AAAA,MAAC,IAAA;AAAA,MAAA;AAAA,QACC,SAAS,EAAA,IAAA;AAAA,QACT,SAAU,EAAA,QAAA;AAAA,QACV,cAAe,EAAA,YAAA;AAAA,QACf,UAAW,EAAA,YAAA;AAAA,QACX,OAAS,EAAA,CAAA;AAAA,OAAA;AAAA,sBAERA,cAAA,CAAA,aAAA,CAAA,IAAA,EAAA,EAAK,IAAI,EAAA,IAAA,EAAA,+CACP,UAAW,EAAA,EAAA,OAAA,EAAQ,OACjB,EAAA,EAAA,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,GAAA,CAAI,QAAJ,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAc,IAAd,KAAA,IAAA,GAAA,EAAA,GAAsB,gBACzB,CACF,CAAA;AAAA,sBACAA,cAAA,CAAA,aAAA,CAAC,IAAK,EAAA,EAAA,IAAA,EAAI,IACR,EAAA,kBAAAA,cAAA,CAAA,aAAA,CAAC,UAAW,EAAA,EAAA,KAAA,EAAM,eAAgB,EAAA,OAAA,EAAQ,WAAY,EAAA,EAAA,KAEtD,CACF,CAAA;AAAA,KACF;AAAA,GACF,CAAA;AAEJ;;;;"}
@@ -0,0 +1,72 @@
1
+ import Button from '@material-ui/core/Button';
2
+ import Dialog from '@material-ui/core/Dialog';
3
+ import DialogContent from '@material-ui/core/DialogContent';
4
+ import DialogTitle from '@material-ui/core/DialogTitle';
5
+ import IconButton from '@material-ui/core/IconButton';
6
+ import { makeStyles, createStyles } from '@material-ui/core/styles';
7
+ import CloseIcon from '@material-ui/icons/Close';
8
+ import React__default, { useState } from 'react';
9
+
10
+ const useStyles = makeStyles(
11
+ (theme) => createStyles({
12
+ dialogPaper: { minHeight: "calc(100% - 64px)" },
13
+ dialogContent: { flexBasis: 0 },
14
+ closeButton: {
15
+ position: "absolute",
16
+ right: theme.spacing(1),
17
+ top: theme.spacing(1),
18
+ color: theme.palette.grey[500]
19
+ }
20
+ })
21
+ );
22
+ const KubernetesDialog = ({
23
+ buttonAriaLabel,
24
+ buttonIcon,
25
+ buttonText,
26
+ children,
27
+ disabled,
28
+ title
29
+ }) => {
30
+ const classes = useStyles();
31
+ const [open, setOpen] = useState(false);
32
+ const openDialog = () => {
33
+ setOpen(true);
34
+ };
35
+ const closeDialog = () => {
36
+ setOpen(false);
37
+ };
38
+ return /* @__PURE__ */ React__default.createElement(React__default.Fragment, null, /* @__PURE__ */ React__default.createElement(
39
+ Dialog,
40
+ {
41
+ maxWidth: "xl",
42
+ fullWidth: true,
43
+ open,
44
+ onClose: closeDialog,
45
+ PaperProps: { className: classes.dialogPaper }
46
+ },
47
+ /* @__PURE__ */ React__default.createElement(DialogTitle, { id: "dialog-title" }, title, /* @__PURE__ */ React__default.createElement(
48
+ IconButton,
49
+ {
50
+ "aria-label": "close",
51
+ className: classes.closeButton,
52
+ onClick: closeDialog
53
+ },
54
+ /* @__PURE__ */ React__default.createElement(CloseIcon, null)
55
+ )),
56
+ /* @__PURE__ */ React__default.createElement(DialogContent, { className: classes.dialogContent }, children)
57
+ ), /* @__PURE__ */ React__default.createElement(
58
+ Button,
59
+ {
60
+ variant: "outlined",
61
+ "aria-label": buttonAriaLabel,
62
+ component: "label",
63
+ disabled,
64
+ onClick: openDialog,
65
+ startIcon: buttonIcon
66
+ },
67
+ buttonText
68
+ ));
69
+ };
70
+
71
+ export { KubernetesDialog };
72
+ //# sourceMappingURL=KubernetesDialog.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"KubernetesDialog.esm.js","sources":["../../../src/components/KubernetesDialog/KubernetesDialog.tsx"],"sourcesContent":["/*\n * Copyright 2024 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 */\n\nimport Button from '@material-ui/core/Button';\nimport Dialog from '@material-ui/core/Dialog';\nimport DialogContent from '@material-ui/core/DialogContent';\nimport DialogTitle from '@material-ui/core/DialogTitle';\nimport IconButton from '@material-ui/core/IconButton';\nimport { Theme, createStyles, makeStyles } from '@material-ui/core/styles';\nimport CloseIcon from '@material-ui/icons/Close';\nimport React, { useState } from 'react';\n\nconst useStyles = makeStyles((theme: Theme) =>\n createStyles({\n dialogPaper: { minHeight: 'calc(100% - 64px)' },\n dialogContent: { flexBasis: 0 },\n closeButton: {\n position: 'absolute',\n right: theme.spacing(1),\n top: theme.spacing(1),\n color: theme.palette.grey[500],\n },\n }),\n);\n\nexport interface KubernetesDialogProps {\n buttonAriaLabel: string;\n buttonIcon: React.ReactNode;\n buttonText: string;\n children?: React.ReactNode;\n disabled?: boolean;\n title: string;\n}\n\n/**\n * Dialog component for use in the Kubernetes plugin\n *\n * @public\n */\nexport const KubernetesDialog = ({\n buttonAriaLabel,\n buttonIcon,\n buttonText,\n children,\n disabled,\n title,\n}: KubernetesDialogProps) => {\n const classes = useStyles();\n\n const [open, setOpen] = useState(false);\n const openDialog = () => {\n setOpen(true);\n };\n const closeDialog = () => {\n setOpen(false);\n };\n\n return (\n <>\n <Dialog\n maxWidth=\"xl\"\n fullWidth\n open={open}\n onClose={closeDialog}\n PaperProps={{ className: classes.dialogPaper }}\n >\n <DialogTitle id=\"dialog-title\">\n {title}\n <IconButton\n aria-label=\"close\"\n className={classes.closeButton}\n onClick={closeDialog}\n >\n <CloseIcon />\n </IconButton>\n </DialogTitle>\n <DialogContent className={classes.dialogContent}>\n {children}\n </DialogContent>\n </Dialog>\n <Button\n variant=\"outlined\"\n aria-label={buttonAriaLabel}\n component=\"label\"\n disabled={disabled}\n onClick={openDialog}\n startIcon={buttonIcon}\n >\n {buttonText}\n </Button>\n </>\n );\n};\n"],"names":["React"],"mappings":";;;;;;;;;AAyBA,MAAM,SAAY,GAAA,UAAA;AAAA,EAAW,CAAC,UAC5B,YAAa,CAAA;AAAA,IACX,WAAA,EAAa,EAAE,SAAA,EAAW,mBAAoB,EAAA;AAAA,IAC9C,aAAA,EAAe,EAAE,SAAA,EAAW,CAAE,EAAA;AAAA,IAC9B,WAAa,EAAA;AAAA,MACX,QAAU,EAAA,UAAA;AAAA,MACV,KAAA,EAAO,KAAM,CAAA,OAAA,CAAQ,CAAC,CAAA;AAAA,MACtB,GAAA,EAAK,KAAM,CAAA,OAAA,CAAQ,CAAC,CAAA;AAAA,MACpB,KAAO,EAAA,KAAA,CAAM,OAAQ,CAAA,IAAA,CAAK,GAAG,CAAA;AAAA,KAC/B;AAAA,GACD,CAAA;AACH,CAAA,CAAA;AAgBO,MAAM,mBAAmB,CAAC;AAAA,EAC/B,eAAA;AAAA,EACA,UAAA;AAAA,EACA,UAAA;AAAA,EACA,QAAA;AAAA,EACA,QAAA;AAAA,EACA,KAAA;AACF,CAA6B,KAAA;AAC3B,EAAA,MAAM,UAAU,SAAU,EAAA,CAAA;AAE1B,EAAA,MAAM,CAAC,IAAA,EAAM,OAAO,CAAA,GAAI,SAAS,KAAK,CAAA,CAAA;AACtC,EAAA,MAAM,aAAa,MAAM;AACvB,IAAA,OAAA,CAAQ,IAAI,CAAA,CAAA;AAAA,GACd,CAAA;AACA,EAAA,MAAM,cAAc,MAAM;AACxB,IAAA,OAAA,CAAQ,KAAK,CAAA,CAAA;AAAA,GACf,CAAA;AAEA,EAAA,uBAEIA,cAAA,CAAA,aAAA,CAAAA,cAAA,CAAA,QAAA,EAAA,IAAA,kBAAAA,cAAA,CAAA,aAAA;AAAA,IAAC,MAAA;AAAA,IAAA;AAAA,MACC,QAAS,EAAA,IAAA;AAAA,MACT,SAAS,EAAA,IAAA;AAAA,MACT,IAAA;AAAA,MACA,OAAS,EAAA,WAAA;AAAA,MACT,UAAY,EAAA,EAAE,SAAW,EAAA,OAAA,CAAQ,WAAY,EAAA;AAAA,KAAA;AAAA,oBAE5CA,cAAA,CAAA,aAAA,CAAA,WAAA,EAAA,EAAY,EAAG,EAAA,cAAA,EAAA,EACb,KACD,kBAAAA,cAAA,CAAA,aAAA;AAAA,MAAC,UAAA;AAAA,MAAA;AAAA,QACC,YAAW,EAAA,OAAA;AAAA,QACX,WAAW,OAAQ,CAAA,WAAA;AAAA,QACnB,OAAS,EAAA,WAAA;AAAA,OAAA;AAAA,mDAER,SAAU,EAAA,IAAA,CAAA;AAAA,KAEf,CAAA;AAAA,oBACCA,cAAA,CAAA,aAAA,CAAA,aAAA,EAAA,EAAc,SAAW,EAAA,OAAA,CAAQ,iBAC/B,QACH,CAAA;AAAA,GAEF,kBAAAA,cAAA,CAAA,aAAA;AAAA,IAAC,MAAA;AAAA,IAAA;AAAA,MACC,OAAQ,EAAA,UAAA;AAAA,MACR,YAAY,EAAA,eAAA;AAAA,MACZ,SAAU,EAAA,OAAA;AAAA,MACV,QAAA;AAAA,MACA,OAAS,EAAA,UAAA;AAAA,MACT,SAAW,EAAA,UAAA;AAAA,KAAA;AAAA,IAEV,UAAA;AAAA,GAEL,CAAA,CAAA;AAEJ;;;;"}
@@ -0,0 +1,117 @@
1
+ import React__default, { useState } from 'react';
2
+ import Drawer from '@material-ui/core/Drawer';
3
+ import Grid from '@material-ui/core/Grid';
4
+ import IconButton from '@material-ui/core/IconButton';
5
+ import Switch from '@material-ui/core/Switch';
6
+ import Typography from '@material-ui/core/Typography';
7
+ import Button from '@material-ui/core/Button';
8
+ import FormControlLabel from '@material-ui/core/FormControlLabel';
9
+ import { makeStyles, createStyles, withStyles } from '@material-ui/core/styles';
10
+ import CloseIcon from '@material-ui/icons/Close';
11
+ import { ManifestYaml } from './ManifestYaml.esm.js';
12
+
13
+ const useDrawerContentStyles = makeStyles(
14
+ (_theme) => createStyles({
15
+ header: {
16
+ display: "flex",
17
+ flexDirection: "row",
18
+ justifyContent: "space-between"
19
+ },
20
+ content: {
21
+ height: "80%"
22
+ },
23
+ icon: {
24
+ fontSize: 20
25
+ }
26
+ })
27
+ );
28
+ const KubernetesDrawerContent = ({
29
+ children,
30
+ header,
31
+ kubernetesObject,
32
+ close
33
+ }) => {
34
+ var _a;
35
+ const classes = useDrawerContentStyles();
36
+ const [isYaml, setIsYaml] = useState(false);
37
+ return /* @__PURE__ */ React__default.createElement(React__default.Fragment, null, /* @__PURE__ */ React__default.createElement("div", { className: classes.header }, /* @__PURE__ */ React__default.createElement(Grid, { container: true, justifyContent: "flex-start", alignItems: "flex-start" }, /* @__PURE__ */ React__default.createElement(Grid, { item: true, xs: 11 }, /* @__PURE__ */ React__default.createElement(Typography, { variant: "h5" }, (_a = kubernetesObject.metadata) == null ? void 0 : _a.name)), /* @__PURE__ */ React__default.createElement(Grid, { item: true, xs: 1 }, /* @__PURE__ */ React__default.createElement(
38
+ IconButton,
39
+ {
40
+ key: "dismiss",
41
+ title: "Close the drawer",
42
+ onClick: () => close(),
43
+ color: "inherit"
44
+ },
45
+ /* @__PURE__ */ React__default.createElement(CloseIcon, { className: classes.icon })
46
+ )), /* @__PURE__ */ React__default.createElement(Grid, { item: true, xs: 12 }, header), /* @__PURE__ */ React__default.createElement(Grid, { item: true, xs: 12 }, /* @__PURE__ */ React__default.createElement(
47
+ FormControlLabel,
48
+ {
49
+ control: /* @__PURE__ */ React__default.createElement(
50
+ Switch,
51
+ {
52
+ checked: isYaml,
53
+ onChange: (event) => {
54
+ setIsYaml(event.target.checked);
55
+ },
56
+ name: "YAML"
57
+ }
58
+ ),
59
+ label: "YAML"
60
+ }
61
+ )))), /* @__PURE__ */ React__default.createElement("div", { className: classes.content }, isYaml && /* @__PURE__ */ React__default.createElement(ManifestYaml, { object: kubernetesObject }), !isYaml && children));
62
+ };
63
+ const useDrawerStyles = makeStyles(
64
+ (theme) => createStyles({
65
+ paper: {
66
+ width: "50%",
67
+ justifyContent: "space-between",
68
+ padding: theme.spacing(2.5)
69
+ }
70
+ })
71
+ );
72
+ const DrawerButton = withStyles({
73
+ root: {
74
+ padding: "6px 5px"
75
+ },
76
+ label: {
77
+ textTransform: "none"
78
+ }
79
+ })(Button);
80
+ const KubernetesDrawer = ({
81
+ open,
82
+ label,
83
+ drawerContentsHeader,
84
+ kubernetesObject,
85
+ children
86
+ }) => {
87
+ const classes = useDrawerStyles();
88
+ const [isOpen, setIsOpen] = useState(open != null ? open : false);
89
+ const toggleDrawer = (e, newValue) => {
90
+ e.stopPropagation();
91
+ setIsOpen(newValue);
92
+ };
93
+ return /* @__PURE__ */ React__default.createElement(React__default.Fragment, null, /* @__PURE__ */ React__default.createElement(DrawerButton, { onClick: () => setIsOpen(true) }, label), /* @__PURE__ */ React__default.createElement(
94
+ Drawer,
95
+ {
96
+ classes: {
97
+ paper: classes.paper
98
+ },
99
+ anchor: "right",
100
+ open: isOpen,
101
+ onClose: (e) => toggleDrawer(e, false),
102
+ onClick: (event) => event.stopPropagation()
103
+ },
104
+ isOpen && /* @__PURE__ */ React__default.createElement(
105
+ KubernetesDrawerContent,
106
+ {
107
+ header: drawerContentsHeader,
108
+ kubernetesObject,
109
+ children,
110
+ close: () => setIsOpen(false)
111
+ }
112
+ )
113
+ ));
114
+ };
115
+
116
+ export { KubernetesDrawer };
117
+ //# sourceMappingURL=KubernetesDrawer.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"KubernetesDrawer.esm.js","sources":["../../../src/components/KubernetesDrawer/KubernetesDrawer.tsx"],"sourcesContent":["/*\n * Copyright 2023 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 React, { ChangeEvent, useState } from 'react';\n\nimport { IObjectMeta } from '@kubernetes-models/apimachinery/apis/meta/v1/ObjectMeta';\nimport Drawer from '@material-ui/core/Drawer';\nimport Grid from '@material-ui/core/Grid';\nimport IconButton from '@material-ui/core/IconButton';\nimport Switch from '@material-ui/core/Switch';\nimport Typography from '@material-ui/core/Typography';\nimport Button from '@material-ui/core/Button';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\nimport {\n createStyles,\n makeStyles,\n Theme,\n withStyles,\n} from '@material-ui/core/styles';\nimport CloseIcon from '@material-ui/icons/Close';\nimport { ManifestYaml } from './ManifestYaml';\n\nconst useDrawerContentStyles = makeStyles((_theme: Theme) =>\n createStyles({\n header: {\n display: 'flex',\n flexDirection: 'row',\n justifyContent: 'space-between',\n },\n content: {\n height: '80%',\n },\n icon: {\n fontSize: 20,\n },\n }),\n);\n\n/**\n * The type of object that can be represented by the Drawer\n *\n * @public\n */\nexport interface KubernetesObject {\n kind: string;\n metadata?: IObjectMeta;\n}\n\ninterface KubernetesDrawerContentProps {\n close: () => void;\n kubernetesObject: KubernetesObject;\n header?: React.ReactNode;\n children?: React.ReactNode;\n}\n\nconst KubernetesDrawerContent = ({\n children,\n header,\n kubernetesObject,\n close,\n}: KubernetesDrawerContentProps) => {\n const classes = useDrawerContentStyles();\n const [isYaml, setIsYaml] = useState<boolean>(false);\n\n return (\n <>\n <div className={classes.header}>\n <Grid container justifyContent=\"flex-start\" alignItems=\"flex-start\">\n <Grid item xs={11}>\n <Typography variant=\"h5\">\n {kubernetesObject.metadata?.name}\n </Typography>\n </Grid>\n <Grid item xs={1}>\n <IconButton\n key=\"dismiss\"\n title=\"Close the drawer\"\n onClick={() => close()}\n color=\"inherit\"\n >\n <CloseIcon className={classes.icon} />\n </IconButton>\n </Grid>\n <Grid item xs={12}>\n {header}\n </Grid>\n <Grid item xs={12}>\n <FormControlLabel\n control={\n <Switch\n checked={isYaml}\n onChange={event => {\n setIsYaml(event.target.checked);\n }}\n name=\"YAML\"\n />\n }\n label=\"YAML\"\n />\n </Grid>\n </Grid>\n </div>\n <div className={classes.content}>\n {isYaml && <ManifestYaml object={kubernetesObject} />}\n {!isYaml && children}\n </div>\n </>\n );\n};\n\n/**\n * Props of KubernetesDrawer\n *\n * @public\n */\nexport interface KubernetesDrawerProps {\n open?: boolean;\n kubernetesObject: KubernetesObject;\n label: React.ReactNode;\n drawerContentsHeader?: React.ReactNode;\n children?: React.ReactNode;\n}\n\nconst useDrawerStyles = makeStyles((theme: Theme) =>\n createStyles({\n paper: {\n width: '50%',\n justifyContent: 'space-between',\n padding: theme.spacing(2.5),\n },\n }),\n);\n\nconst DrawerButton = withStyles({\n root: {\n padding: '6px 5px',\n },\n label: {\n textTransform: 'none',\n },\n})(Button);\n\n/**\n * Button/Drawer component for Kubernetes Objects\n *\n * @public\n */\nexport const KubernetesDrawer = ({\n open,\n label,\n drawerContentsHeader,\n kubernetesObject,\n children,\n}: KubernetesDrawerProps) => {\n const classes = useDrawerStyles();\n const [isOpen, setIsOpen] = useState<boolean>(open ?? false);\n\n const toggleDrawer = (e: ChangeEvent<{}>, newValue: boolean) => {\n e.stopPropagation();\n setIsOpen(newValue);\n };\n\n return (\n <>\n <DrawerButton onClick={() => setIsOpen(true)}>{label}</DrawerButton>\n <Drawer\n classes={{\n paper: classes.paper,\n }}\n anchor=\"right\"\n open={isOpen}\n onClose={(e: any) => toggleDrawer(e, false)}\n onClick={event => event.stopPropagation()}\n >\n {isOpen && (\n <KubernetesDrawerContent\n header={drawerContentsHeader}\n kubernetesObject={kubernetesObject}\n children={children}\n close={() => setIsOpen(false)}\n />\n )}\n </Drawer>\n </>\n );\n};\n"],"names":["React"],"mappings":"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"}
@@ -0,0 +1,199 @@
1
+ import React__default, { useState, useContext } from 'react';
2
+ import Button from '@material-ui/core/Button';
3
+ import Typography from '@material-ui/core/Typography';
4
+ import IconButton from '@material-ui/core/IconButton';
5
+ import Drawer from '@material-ui/core/Drawer';
6
+ import Switch from '@material-ui/core/Switch';
7
+ import FormControlLabel from '@material-ui/core/FormControlLabel';
8
+ import Grid from '@material-ui/core/Grid';
9
+ import { makeStyles, createStyles, withStyles } from '@material-ui/core/styles';
10
+ import CloseIcon from '@material-ui/icons/Close';
11
+ import OpenInNewIcon from '@material-ui/icons/OpenInNew';
12
+ import { WarningPanel, LinkButton, StructuredMetadataTable } from '@backstage/core-components';
13
+ import { useApi } from '@backstage/core-plugin-api';
14
+ import useAsync from 'react-use/esm/useAsync';
15
+ import { kubernetesClusterLinkFormatterApiRef } from '../../api/types.esm.js';
16
+ import 'react-use/esm/useInterval';
17
+ import 'react-use/esm/useAsyncRetry';
18
+ import '../../kubernetes-auth-provider/types.esm.js';
19
+ import '../../hooks/PodNamesWithErrors.esm.js';
20
+ import '../../hooks/PodNamesWithMetrics.esm.js';
21
+ import '../../hooks/GroupedResponses.esm.js';
22
+ import { ClusterContext } from '../../hooks/Cluster.esm.js';
23
+ import '../../hooks/usePodMetrics.esm.js';
24
+ import '../../hooks/useMatchingErrors.esm.js';
25
+ import { ManifestYaml } from './ManifestYaml.esm.js';
26
+ import '@backstage/catalog-model';
27
+ import '@backstage/errors';
28
+
29
+ const useDrawerStyles = makeStyles(
30
+ (theme) => createStyles({
31
+ paper: {
32
+ width: "50%",
33
+ justifyContent: "space-between",
34
+ padding: theme.spacing(2.5)
35
+ }
36
+ })
37
+ );
38
+ const useDrawerContentStyles = makeStyles(
39
+ (_) => createStyles({
40
+ header: {
41
+ display: "flex",
42
+ flexDirection: "row",
43
+ justifyContent: "space-between"
44
+ },
45
+ errorMessage: {
46
+ marginTop: "1em",
47
+ marginBottom: "1em"
48
+ },
49
+ options: {
50
+ display: "flex",
51
+ flexDirection: "row",
52
+ justifyContent: "space-between"
53
+ },
54
+ icon: {
55
+ fontSize: 20
56
+ },
57
+ content: {
58
+ height: "80%"
59
+ }
60
+ })
61
+ );
62
+ const PodDrawerButton = withStyles({
63
+ root: {
64
+ padding: "6px 5px"
65
+ },
66
+ label: {
67
+ textTransform: "none"
68
+ }
69
+ })(Button);
70
+ const LinkErrorPanel = ({
71
+ cluster,
72
+ errorMessage
73
+ }) => /* @__PURE__ */ React__default.createElement(
74
+ WarningPanel,
75
+ {
76
+ title: "There was a problem formatting the link to the Kubernetes dashboard",
77
+ message: `Could not format the link to the dashboard of your cluster named '${cluster.name}'. Its dashboardApp property has been set to '${cluster.dashboardApp || "standard"}.'`
78
+ },
79
+ errorMessage && /* @__PURE__ */ React__default.createElement(Typography, { variant: "body2" }, "Errors: ", errorMessage)
80
+ );
81
+ function replaceNullsWithUndefined(someObj) {
82
+ const replacer = (_, value) => String(value) === "null" || String(value) === "undefined" ? void 0 : value;
83
+ return JSON.parse(JSON.stringify(someObj, replacer));
84
+ }
85
+ const KubernetesStructuredMetadataTableDrawerContent = ({
86
+ toggleDrawer,
87
+ object,
88
+ renderObject,
89
+ kind
90
+ }) => {
91
+ var _a, _b;
92
+ const [isYaml, setIsYaml] = useState(false);
93
+ const formatter = useApi(kubernetesClusterLinkFormatterApiRef);
94
+ const classes = useDrawerContentStyles();
95
+ const cluster = useContext(ClusterContext);
96
+ const { value: clusterLink, error } = useAsync(
97
+ async () => formatter.formatClusterLink({
98
+ dashboardUrl: cluster.dashboardUrl,
99
+ dashboardApp: cluster.dashboardApp,
100
+ dashboardParameters: cluster.dashboardParameters,
101
+ object,
102
+ kind
103
+ }),
104
+ [cluster, object, kind, formatter]
105
+ );
106
+ return /* @__PURE__ */ React__default.createElement(React__default.Fragment, null, /* @__PURE__ */ React__default.createElement("div", { className: classes.header }, /* @__PURE__ */ React__default.createElement(Grid, { container: true, justifyContent: "flex-start", alignItems: "flex-start" }, /* @__PURE__ */ React__default.createElement(Grid, { item: true, xs: 11 }, /* @__PURE__ */ React__default.createElement(Typography, { variant: "h5" }, (_b = (_a = object.metadata) == null ? void 0 : _a.name) != null ? _b : "unknown name")), /* @__PURE__ */ React__default.createElement(Grid, { item: true, xs: 1 }, /* @__PURE__ */ React__default.createElement(
107
+ IconButton,
108
+ {
109
+ key: "dismiss",
110
+ title: "Close the drawer",
111
+ onClick: (e) => toggleDrawer(e, false),
112
+ color: "inherit"
113
+ },
114
+ /* @__PURE__ */ React__default.createElement(CloseIcon, { className: classes.icon })
115
+ )), /* @__PURE__ */ React__default.createElement(Grid, { item: true, xs: 11 }, /* @__PURE__ */ React__default.createElement(Typography, { color: "textSecondary", variant: "body1" }, kind)), /* @__PURE__ */ React__default.createElement(Grid, { item: true, xs: 11 }, /* @__PURE__ */ React__default.createElement(
116
+ FormControlLabel,
117
+ {
118
+ control: /* @__PURE__ */ React__default.createElement(
119
+ Switch,
120
+ {
121
+ checked: isYaml,
122
+ onChange: (event) => {
123
+ setIsYaml(event.target.checked);
124
+ },
125
+ name: "YAML"
126
+ }
127
+ ),
128
+ label: "YAML"
129
+ }
130
+ )))), error && /* @__PURE__ */ React__default.createElement("div", { className: classes.errorMessage }, /* @__PURE__ */ React__default.createElement(
131
+ LinkErrorPanel,
132
+ {
133
+ cluster,
134
+ errorMessage: error.message || error.toString()
135
+ }
136
+ )), /* @__PURE__ */ React__default.createElement("div", { className: classes.options }, /* @__PURE__ */ React__default.createElement("div", null, clusterLink && /* @__PURE__ */ React__default.createElement(
137
+ LinkButton,
138
+ {
139
+ variant: "outlined",
140
+ color: "primary",
141
+ size: "small",
142
+ to: clusterLink,
143
+ endIcon: /* @__PURE__ */ React__default.createElement(OpenInNewIcon, null)
144
+ },
145
+ "Open Kubernetes Dashboard"
146
+ ))), /* @__PURE__ */ React__default.createElement("div", { className: classes.content }, isYaml && /* @__PURE__ */ React__default.createElement(ManifestYaml, { object }), !isYaml && /* @__PURE__ */ React__default.createElement(
147
+ StructuredMetadataTable,
148
+ {
149
+ metadata: renderObject(replaceNullsWithUndefined(object))
150
+ }
151
+ )));
152
+ };
153
+ const KubernetesStructuredMetadataTableDrawer = ({
154
+ object,
155
+ renderObject,
156
+ kind,
157
+ buttonVariant = "subtitle2",
158
+ expanded = false,
159
+ children
160
+ }) => {
161
+ var _a, _b;
162
+ const [isOpen, setIsOpen] = useState(expanded);
163
+ const classes = useDrawerStyles();
164
+ const toggleDrawer = (e, newValue) => {
165
+ e.stopPropagation();
166
+ setIsOpen(newValue);
167
+ };
168
+ return /* @__PURE__ */ React__default.createElement(React__default.Fragment, null, /* @__PURE__ */ React__default.createElement(
169
+ PodDrawerButton,
170
+ {
171
+ onClick: (e) => toggleDrawer(e, true),
172
+ onFocus: (event) => event.stopPropagation()
173
+ },
174
+ children === void 0 ? /* @__PURE__ */ React__default.createElement(Typography, { variant: buttonVariant }, (_b = (_a = object.metadata) == null ? void 0 : _a.name) != null ? _b : "unknown object") : children
175
+ ), /* @__PURE__ */ React__default.createElement(
176
+ Drawer,
177
+ {
178
+ classes: {
179
+ paper: classes.paper
180
+ },
181
+ anchor: "right",
182
+ open: isOpen,
183
+ onClose: (e) => toggleDrawer(e, false),
184
+ onClick: (event) => event.stopPropagation()
185
+ },
186
+ /* @__PURE__ */ React__default.createElement(
187
+ KubernetesStructuredMetadataTableDrawerContent,
188
+ {
189
+ kind,
190
+ toggleDrawer,
191
+ object,
192
+ renderObject
193
+ }
194
+ )
195
+ ));
196
+ };
197
+
198
+ export { KubernetesStructuredMetadataTableDrawer, LinkErrorPanel };
199
+ //# sourceMappingURL=KubernetesStructuredMetadataTableDrawer.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"KubernetesStructuredMetadataTableDrawer.esm.js","sources":["../../../src/components/KubernetesDrawer/KubernetesStructuredMetadataTableDrawer.tsx"],"sourcesContent":["/*\n * Copyright 2020 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 */\n\nimport React, { ChangeEvent, useContext, useState } from 'react';\nimport Button from '@material-ui/core/Button';\nimport Typography from '@material-ui/core/Typography';\nimport IconButton from '@material-ui/core/IconButton';\nimport Drawer from '@material-ui/core/Drawer';\nimport Switch from '@material-ui/core/Switch';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\nimport Grid from '@material-ui/core/Grid';\nimport { makeStyles, createStyles, Theme } from '@material-ui/core/styles';\nimport Close from '@material-ui/icons/Close';\nimport OpenInNewIcon from '@material-ui/icons/OpenInNew';\nimport { V1ObjectMeta } from '@kubernetes/client-node';\nimport { withStyles } from '@material-ui/core/styles';\nimport {\n LinkButton as BackstageButton,\n StructuredMetadataTable,\n WarningPanel,\n} from '@backstage/core-components';\nimport { ClusterContext } from '../../hooks';\nimport { ClusterAttributes } from '@backstage/plugin-kubernetes-common';\nimport { ManifestYaml } from './ManifestYaml';\nimport { useApi } from '@backstage/core-plugin-api';\nimport { kubernetesClusterLinkFormatterApiRef } from '../../api';\nimport useAsync from 'react-use/esm/useAsync';\n\nconst useDrawerStyles = makeStyles((theme: Theme) =>\n createStyles({\n paper: {\n width: '50%',\n justifyContent: 'space-between',\n padding: theme.spacing(2.5),\n },\n }),\n);\n\nconst useDrawerContentStyles = makeStyles((_: Theme) =>\n createStyles({\n header: {\n display: 'flex',\n flexDirection: 'row',\n justifyContent: 'space-between',\n },\n errorMessage: {\n marginTop: '1em',\n marginBottom: '1em',\n },\n options: {\n display: 'flex',\n flexDirection: 'row',\n justifyContent: 'space-between',\n },\n icon: {\n fontSize: 20,\n },\n content: {\n height: '80%',\n },\n }),\n);\n\nconst PodDrawerButton = withStyles({\n root: {\n padding: '6px 5px',\n },\n label: {\n textTransform: 'none',\n },\n})(Button);\n\n/**\n *\n *\n * @public\n */\nexport type LinkErrorPanelProps = {\n cluster: ClusterAttributes;\n errorMessage?: string;\n children?: React.ReactNode;\n};\n\n/**\n *\n *\n * @public\n */\nexport const LinkErrorPanel = ({\n cluster,\n errorMessage,\n}: LinkErrorPanelProps) => (\n <WarningPanel\n title=\"There was a problem formatting the link to the Kubernetes dashboard\"\n message={`Could not format the link to the dashboard of your cluster named '${\n cluster.name\n }'. Its dashboardApp property has been set to '${\n cluster.dashboardApp || 'standard'\n }.'`}\n >\n {errorMessage && (\n <Typography variant=\"body2\">Errors: {errorMessage}</Typography>\n )}\n </WarningPanel>\n);\n\n/**\n *\n *\n * @public\n */\nexport interface KubernetesDrawerable {\n metadata?: V1ObjectMeta;\n}\n\ninterface KubernetesStructuredMetadataTableDrawerContentProps<\n T extends KubernetesDrawerable,\n> {\n toggleDrawer: (e: ChangeEvent<{}>, isOpen: boolean) => void;\n object: T;\n renderObject: (obj: T) => object;\n kind: string;\n}\n\nfunction replaceNullsWithUndefined(someObj: any) {\n const replacer = (_: any, value: any) =>\n String(value) === 'null' || String(value) === 'undefined'\n ? undefined\n : value;\n\n return JSON.parse(JSON.stringify(someObj, replacer));\n}\n\nconst KubernetesStructuredMetadataTableDrawerContent = <\n T extends KubernetesDrawerable,\n>({\n toggleDrawer,\n object,\n renderObject,\n kind,\n}: KubernetesStructuredMetadataTableDrawerContentProps<T>) => {\n const [isYaml, setIsYaml] = useState<boolean>(false);\n\n const formatter = useApi(kubernetesClusterLinkFormatterApiRef);\n const classes = useDrawerContentStyles();\n const cluster = useContext(ClusterContext);\n const { value: clusterLink, error } = useAsync(\n async () =>\n formatter.formatClusterLink({\n dashboardUrl: cluster.dashboardUrl,\n dashboardApp: cluster.dashboardApp,\n dashboardParameters: cluster.dashboardParameters,\n object,\n kind,\n }),\n [cluster, object, kind, formatter],\n );\n\n return (\n <>\n <div className={classes.header}>\n <Grid container justifyContent=\"flex-start\" alignItems=\"flex-start\">\n <Grid item xs={11}>\n <Typography variant=\"h5\">\n {object.metadata?.name ?? 'unknown name'}\n </Typography>\n </Grid>\n <Grid item xs={1}>\n <IconButton\n key=\"dismiss\"\n title=\"Close the drawer\"\n onClick={e => toggleDrawer(e, false)}\n color=\"inherit\"\n >\n <Close className={classes.icon} />\n </IconButton>\n </Grid>\n <Grid item xs={11}>\n <Typography color=\"textSecondary\" variant=\"body1\">\n {kind}\n </Typography>\n </Grid>\n <Grid item xs={11}>\n <FormControlLabel\n control={\n <Switch\n checked={isYaml}\n onChange={event => {\n setIsYaml(event.target.checked);\n }}\n name=\"YAML\"\n />\n }\n label=\"YAML\"\n />\n </Grid>\n </Grid>\n </div>\n {error && (\n <div className={classes.errorMessage}>\n <LinkErrorPanel\n cluster={cluster}\n errorMessage={error.message || error.toString()}\n />\n </div>\n )}\n <div className={classes.options}>\n <div>\n {clusterLink && (\n <BackstageButton\n variant=\"outlined\"\n color=\"primary\"\n size=\"small\"\n to={clusterLink}\n endIcon={<OpenInNewIcon />}\n >\n Open Kubernetes Dashboard\n </BackstageButton>\n )}\n </div>\n </div>\n <div className={classes.content}>\n {isYaml && <ManifestYaml object={object} />}\n {!isYaml && (\n <StructuredMetadataTable\n metadata={renderObject(replaceNullsWithUndefined(object))}\n />\n )}\n </div>\n </>\n );\n};\n\n/**\n *\n * @public\n */\nexport interface KubernetesStructuredMetadataTableDrawerProps<\n T extends KubernetesDrawerable,\n> {\n object: T;\n renderObject: (obj: T) => object;\n buttonVariant?: 'h5' | 'subtitle2';\n kind: string;\n expanded?: boolean;\n children?: React.ReactNode;\n}\n\n/**\n *\n * @public\n */\nexport const KubernetesStructuredMetadataTableDrawer = <\n T extends KubernetesDrawerable,\n>({\n object,\n renderObject,\n kind,\n buttonVariant = 'subtitle2',\n expanded = false,\n children,\n}: KubernetesStructuredMetadataTableDrawerProps<T>) => {\n const [isOpen, setIsOpen] = useState(expanded);\n const classes = useDrawerStyles();\n\n const toggleDrawer = (e: ChangeEvent<{}>, newValue: boolean) => {\n e.stopPropagation();\n setIsOpen(newValue);\n };\n\n return (\n <>\n <PodDrawerButton\n onClick={e => toggleDrawer(e, true)}\n onFocus={event => event.stopPropagation()}\n >\n {children === undefined ? (\n <Typography variant={buttonVariant}>\n {object.metadata?.name ?? 'unknown object'}\n </Typography>\n ) : (\n children\n )}\n </PodDrawerButton>\n <Drawer\n classes={{\n paper: classes.paper,\n }}\n anchor=\"right\"\n open={isOpen}\n onClose={(e: any) => toggleDrawer(e, false)}\n onClick={event => event.stopPropagation()}\n >\n <KubernetesStructuredMetadataTableDrawerContent\n kind={kind}\n toggleDrawer={toggleDrawer}\n object={object}\n renderObject={renderObject}\n />\n </Drawer>\n </>\n );\n};\n"],"names":["React","Close","BackstageButton"],"mappings":"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"}
@@ -0,0 +1,44 @@
1
+ import { CodeSnippet } from '@backstage/core-components';
2
+ import FormControlLabel from '@material-ui/core/FormControlLabel';
3
+ import Switch from '@material-ui/core/Switch';
4
+ import jsyaml from 'js-yaml';
5
+ import React__default, { useState } from 'react';
6
+
7
+ const ManifestYaml = ({ object }) => {
8
+ const [managedFields, setManagedFields] = useState(false);
9
+ return /* @__PURE__ */ React__default.createElement(React__default.Fragment, null, /* @__PURE__ */ React__default.createElement(
10
+ FormControlLabel,
11
+ {
12
+ control: /* @__PURE__ */ React__default.createElement(
13
+ Switch,
14
+ {
15
+ checked: managedFields,
16
+ onChange: (event) => {
17
+ setManagedFields(event.target.checked);
18
+ },
19
+ name: "Managed Fields"
20
+ }
21
+ ),
22
+ label: "Managed Fields"
23
+ }
24
+ ), /* @__PURE__ */ React__default.createElement(
25
+ CodeSnippet,
26
+ {
27
+ language: "yaml",
28
+ text: jsyaml.dump(object, {
29
+ // NOTE: this will remove any field called `managedFields`
30
+ // not just the metadata one
31
+ // TODO: @mclarke make this only remove the `metadata.managedFields`
32
+ replacer: (key, value) => {
33
+ if (!managedFields) {
34
+ return key === "managedFields" ? void 0 : value;
35
+ }
36
+ return value;
37
+ }
38
+ })
39
+ }
40
+ ));
41
+ };
42
+
43
+ export { ManifestYaml };
44
+ //# sourceMappingURL=ManifestYaml.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ManifestYaml.esm.js","sources":["../../../src/components/KubernetesDrawer/ManifestYaml.tsx"],"sourcesContent":["/*\n * Copyright 2023 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 { CodeSnippet } from '@backstage/core-components';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\nimport Switch from '@material-ui/core/Switch';\nimport jsyaml from 'js-yaml';\nimport React, { useState } from 'react';\n\n/**\n * Props of ManifestYaml\n *\n * @public\n */\nexport interface ManifestYamlProps {\n object: object;\n}\n\n/**\n * Renders a Kubernetes object as a YAML code snippet\n *\n * @public\n */\nexport const ManifestYaml = ({ object }: ManifestYamlProps) => {\n // Toggle whether the Kubernetes resource managed fields should be shown in\n // the YAML display. This toggle is only available when the YAML is being\n // shown because managed fields are never visible in the structured display.\n const [managedFields, setManagedFields] = useState<boolean>(false);\n return (\n <>\n <FormControlLabel\n control={\n <Switch\n checked={managedFields}\n onChange={event => {\n setManagedFields(event.target.checked);\n }}\n name=\"Managed Fields\"\n />\n }\n label=\"Managed Fields\"\n />\n <CodeSnippet\n language=\"yaml\"\n text={jsyaml.dump(object, {\n // NOTE: this will remove any field called `managedFields`\n // not just the metadata one\n // TODO: @mclarke make this only remove the `metadata.managedFields`\n replacer: (key: string, value: string): any => {\n if (!managedFields) {\n return key === 'managedFields' ? undefined : value;\n }\n return value;\n },\n })}\n />\n </>\n );\n};\n"],"names":["React"],"mappings":";;;;;;AAmCO,MAAM,YAAe,GAAA,CAAC,EAAE,MAAA,EAAgC,KAAA;AAI7D,EAAA,MAAM,CAAC,aAAA,EAAe,gBAAgB,CAAA,GAAI,SAAkB,KAAK,CAAA,CAAA;AACjE,EAAA,uBAEIA,cAAA,CAAA,aAAA,CAAAA,cAAA,CAAA,QAAA,EAAA,IAAA,kBAAAA,cAAA,CAAA,aAAA;AAAA,IAAC,gBAAA;AAAA,IAAA;AAAA,MACC,OACE,kBAAAA,cAAA,CAAA,aAAA;AAAA,QAAC,MAAA;AAAA,QAAA;AAAA,UACC,OAAS,EAAA,aAAA;AAAA,UACT,UAAU,CAAS,KAAA,KAAA;AACjB,YAAiB,gBAAA,CAAA,KAAA,CAAM,OAAO,OAAO,CAAA,CAAA;AAAA,WACvC;AAAA,UACA,IAAK,EAAA,gBAAA;AAAA,SAAA;AAAA,OACP;AAAA,MAEF,KAAM,EAAA,gBAAA;AAAA,KAAA;AAAA,GAER,kBAAAA,cAAA,CAAA,aAAA;AAAA,IAAC,WAAA;AAAA,IAAA;AAAA,MACC,QAAS,EAAA,MAAA;AAAA,MACT,IAAA,EAAM,MAAO,CAAA,IAAA,CAAK,MAAQ,EAAA;AAAA;AAAA;AAAA;AAAA,QAIxB,QAAA,EAAU,CAAC,GAAA,EAAa,KAAuB,KAAA;AAC7C,UAAA,IAAI,CAAC,aAAe,EAAA;AAClB,YAAO,OAAA,GAAA,KAAQ,kBAAkB,KAAY,CAAA,GAAA,KAAA,CAAA;AAAA,WAC/C;AACA,UAAO,OAAA,KAAA,CAAA;AAAA,SACT;AAAA,OACD,CAAA;AAAA,KAAA;AAAA,GAEL,CAAA,CAAA;AAEJ;;;;"}