@backstage-community/plugin-ocm 5.2.5 → 5.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,25 @@
1
1
  ### Dependencies
2
2
 
3
+ ## 5.3.0
4
+
5
+ ### Minor Changes
6
+
7
+ - e0796ca: Backstage version bump to v1.35.0
8
+
9
+ ### Patch Changes
10
+
11
+ - Updated dependencies [e0796ca]
12
+ - @backstage-community/plugin-ocm-common@3.7.0
13
+
14
+ ## 5.2.6
15
+
16
+ ### Patch Changes
17
+
18
+ - 0f5c451: Updated dependency `prettier` to `3.4.2`.
19
+ - 18f9d9d: Updated dependency `@types/node` to `18.19.68`.
20
+ - Updated dependencies [0f5c451]
21
+ - @backstage-community/plugin-ocm-common@3.6.3
22
+
3
23
  ## 5.2.5
4
24
 
5
25
  ### Patch Changes
@@ -1 +1 @@
1
- {"version":3,"file":"index.esm.js","sources":["../../src/api/index.ts"],"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 */\nimport {\n ConfigApi,\n createApiRef,\n IdentityApi,\n} from '@backstage/core-plugin-api';\nimport { ErrorResponseBody } from '@backstage/errors';\n\nimport { Cluster } from '@backstage-community/plugin-ocm-common';\n\nexport interface OcmApiV1 {\n getClusters(): Promise<Cluster[] | ErrorResponseBody>;\n getClusterByName(\n providerId: string,\n name: string,\n ): Promise<Cluster | ErrorResponseBody>;\n}\n\nexport type Options = {\n configApi: ConfigApi;\n identityApi: IdentityApi;\n};\n\nexport const OcmApiRef = createApiRef<OcmApiV1>({\n id: 'plugin.ocm.service',\n});\n\nexport class OcmApiClient implements OcmApiV1 {\n private readonly configApi: ConfigApi;\n private readonly identityApi: IdentityApi;\n\n constructor(options: Options) {\n this.configApi = options.configApi;\n this.identityApi = options.identityApi;\n }\n\n private async clusterApiFetchCall(params?: string): Promise<any> {\n const { token: idToken } = await this.identityApi.getCredentials();\n const backendUrl = this.configApi.getString('backend.baseUrl');\n const jsonResponse = await fetch(\n `${backendUrl}/api/ocm/status${params || ''}`,\n {\n headers: {\n ...(idToken && { Authorization: `Bearer ${idToken}` }),\n },\n },\n );\n return jsonResponse.json();\n }\n\n getClusters(): Promise<ErrorResponseBody | Cluster[]> {\n return this.clusterApiFetchCall();\n }\n getClusterByName(\n providerId: string,\n name: string,\n ): Promise<Cluster | ErrorResponseBody> {\n return this.clusterApiFetchCall(`/${providerId}/${name}`);\n }\n}\n"],"names":[],"mappings":";;AAqCO,MAAM,YAAY,YAAuB,CAAA;AAAA,EAC9C,EAAI,EAAA,oBAAA;AACN,CAAC,EAAA;AAEM,MAAM,YAAiC,CAAA;AAAA,EAC3B,SAAA,CAAA;AAAA,EACA,WAAA,CAAA;AAAA,EAEjB,YAAY,OAAkB,EAAA;AAC5B,IAAA,IAAA,CAAK,YAAY,OAAQ,CAAA,SAAA,CAAA;AACzB,IAAA,IAAA,CAAK,cAAc,OAAQ,CAAA,WAAA,CAAA;AAAA,GAC7B;AAAA,EAEA,MAAc,oBAAoB,MAA+B,EAAA;AAC/D,IAAA,MAAM,EAAE,KAAO,EAAA,OAAA,KAAY,MAAM,IAAA,CAAK,YAAY,cAAe,EAAA,CAAA;AACjE,IAAA,MAAM,UAAa,GAAA,IAAA,CAAK,SAAU,CAAA,SAAA,CAAU,iBAAiB,CAAA,CAAA;AAC7D,IAAA,MAAM,eAAe,MAAM,KAAA;AAAA,MACzB,CAAG,EAAA,UAAU,CAAkB,eAAA,EAAA,MAAA,IAAU,EAAE,CAAA,CAAA;AAAA,MAC3C;AAAA,QACE,OAAS,EAAA;AAAA,UACP,GAAI,OAAW,IAAA,EAAE,aAAe,EAAA,CAAA,OAAA,EAAU,OAAO,CAAG,CAAA,EAAA;AAAA,SACtD;AAAA,OACF;AAAA,KACF,CAAA;AACA,IAAA,OAAO,aAAa,IAAK,EAAA,CAAA;AAAA,GAC3B;AAAA,EAEA,WAAsD,GAAA;AACpD,IAAA,OAAO,KAAK,mBAAoB,EAAA,CAAA;AAAA,GAClC;AAAA,EACA,gBAAA,CACE,YACA,IACsC,EAAA;AACtC,IAAA,OAAO,KAAK,mBAAoB,CAAA,CAAA,CAAA,EAAI,UAAU,CAAA,CAAA,EAAI,IAAI,CAAE,CAAA,CAAA,CAAA;AAAA,GAC1D;AACF;;;;"}
1
+ {"version":3,"file":"index.esm.js","sources":["../../src/api/index.ts"],"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 */\nimport {\n ConfigApi,\n createApiRef,\n IdentityApi,\n} from '@backstage/core-plugin-api';\nimport { ErrorResponseBody } from '@backstage/errors';\n\nimport { Cluster } from '@backstage-community/plugin-ocm-common';\n\nexport interface OcmApiV1 {\n getClusters(): Promise<Cluster[] | ErrorResponseBody>;\n getClusterByName(\n providerId: string,\n name: string,\n ): Promise<Cluster | ErrorResponseBody>;\n}\n\nexport type Options = {\n configApi: ConfigApi;\n identityApi: IdentityApi;\n};\n\nexport const OcmApiRef = createApiRef<OcmApiV1>({\n id: 'plugin.ocm.service',\n});\n\nexport class OcmApiClient implements OcmApiV1 {\n private readonly configApi: ConfigApi;\n private readonly identityApi: IdentityApi;\n\n constructor(options: Options) {\n this.configApi = options.configApi;\n this.identityApi = options.identityApi;\n }\n\n private async clusterApiFetchCall(params?: string): Promise<any> {\n const { token: idToken } = await this.identityApi.getCredentials();\n const backendUrl = this.configApi.getString('backend.baseUrl');\n const jsonResponse = await fetch(\n `${backendUrl}/api/ocm/status${params || ''}`,\n {\n headers: {\n ...(idToken && { Authorization: `Bearer ${idToken}` }),\n },\n },\n );\n return jsonResponse.json();\n }\n\n getClusters(): Promise<ErrorResponseBody | Cluster[]> {\n return this.clusterApiFetchCall();\n }\n getClusterByName(\n providerId: string,\n name: string,\n ): Promise<Cluster | ErrorResponseBody> {\n return this.clusterApiFetchCall(`/${providerId}/${name}`);\n }\n}\n"],"names":[],"mappings":";;AAqCO,MAAM,YAAY,YAAuB,CAAA;AAAA,EAC9C,EAAI,EAAA;AACN,CAAC;AAEM,MAAM,YAAiC,CAAA;AAAA,EAC3B,SAAA;AAAA,EACA,WAAA;AAAA,EAEjB,YAAY,OAAkB,EAAA;AAC5B,IAAA,IAAA,CAAK,YAAY,OAAQ,CAAA,SAAA;AACzB,IAAA,IAAA,CAAK,cAAc,OAAQ,CAAA,WAAA;AAAA;AAC7B,EAEA,MAAc,oBAAoB,MAA+B,EAAA;AAC/D,IAAA,MAAM,EAAE,KAAO,EAAA,OAAA,KAAY,MAAM,IAAA,CAAK,YAAY,cAAe,EAAA;AACjE,IAAA,MAAM,UAAa,GAAA,IAAA,CAAK,SAAU,CAAA,SAAA,CAAU,iBAAiB,CAAA;AAC7D,IAAA,MAAM,eAAe,MAAM,KAAA;AAAA,MACzB,CAAG,EAAA,UAAU,CAAkB,eAAA,EAAA,MAAA,IAAU,EAAE,CAAA,CAAA;AAAA,MAC3C;AAAA,QACE,OAAS,EAAA;AAAA,UACP,GAAI,OAAW,IAAA,EAAE,aAAe,EAAA,CAAA,OAAA,EAAU,OAAO,CAAG,CAAA;AAAA;AACtD;AACF,KACF;AACA,IAAA,OAAO,aAAa,IAAK,EAAA;AAAA;AAC3B,EAEA,WAAsD,GAAA;AACpD,IAAA,OAAO,KAAK,mBAAoB,EAAA;AAAA;AAClC,EACA,gBAAA,CACE,YACA,IACsC,EAAA;AACtC,IAAA,OAAO,KAAK,mBAAoB,CAAA,CAAA,CAAA,EAAI,UAAU,CAAA,CAAA,EAAI,IAAI,CAAE,CAAA,CAAA;AAAA;AAE5D;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"ClusterAvailableResourcesCard.esm.js","sources":["../../../src/components/ClusterAvailableResourcesCard/ClusterAvailableResourcesCard.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 */\nimport React from 'react';\n\nimport { RequirePermission } from '@backstage/plugin-permission-react';\n\nimport { ocmEntityReadPermission } from '@backstage-community/plugin-ocm-common';\n\nimport { useCluster } from '../ClusterContext';\nimport { TableCardFromData } from '../TableCardFromData';\n\n/**\n * @public\n */\nexport const ClusterAvailableResourceCard = (): any => {\n const { data } = useCluster();\n\n if (!data) {\n return null;\n }\n\n if (!('availableResources' in data!)) {\n return null;\n }\n\n const nameMap = new Map<string, string>([\n ['cpuCores', 'CPU cores'],\n ['memorySize', 'Memory size'],\n ['numberOfPods', 'Number of pods'],\n ]);\n return (\n <RequirePermission permission={ocmEntityReadPermission}>\n <TableCardFromData\n data={data.availableResources}\n title=\"Available\"\n nameMap={nameMap}\n />\n </RequirePermission>\n );\n};\n"],"names":[],"mappings":";;;;;;AA2BO,MAAM,+BAA+B,MAAW;AACrD,EAAM,MAAA,EAAE,IAAK,EAAA,GAAI,UAAW,EAAA,CAAA;AAE5B,EAAA,IAAI,CAAC,IAAM,EAAA;AACT,IAAO,OAAA,IAAA,CAAA;AAAA,GACT;AAEA,EAAI,IAAA,EAAE,wBAAwB,IAAQ,CAAA,EAAA;AACpC,IAAO,OAAA,IAAA,CAAA;AAAA,GACT;AAEA,EAAM,MAAA,OAAA,uBAAc,GAAoB,CAAA;AAAA,IACtC,CAAC,YAAY,WAAW,CAAA;AAAA,IACxB,CAAC,cAAc,aAAa,CAAA;AAAA,IAC5B,CAAC,gBAAgB,gBAAgB,CAAA;AAAA,GAClC,CAAA,CAAA;AACD,EACE,uBAAA,KAAA,CAAA,aAAA,CAAC,iBAAkB,EAAA,EAAA,UAAA,EAAY,uBAC7B,EAAA,kBAAA,KAAA,CAAA,aAAA;AAAA,IAAC,iBAAA;AAAA,IAAA;AAAA,MACC,MAAM,IAAK,CAAA,kBAAA;AAAA,MACX,KAAM,EAAA,WAAA;AAAA,MACN,OAAA;AAAA,KAAA;AAAA,GAEJ,CAAA,CAAA;AAEJ;;;;"}
1
+ {"version":3,"file":"ClusterAvailableResourcesCard.esm.js","sources":["../../../src/components/ClusterAvailableResourcesCard/ClusterAvailableResourcesCard.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 */\nimport React from 'react';\n\nimport { RequirePermission } from '@backstage/plugin-permission-react';\n\nimport { ocmEntityReadPermission } from '@backstage-community/plugin-ocm-common';\n\nimport { useCluster } from '../ClusterContext';\nimport { TableCardFromData } from '../TableCardFromData';\n\n/**\n * @public\n */\nexport const ClusterAvailableResourceCard = (): any => {\n const { data } = useCluster();\n\n if (!data) {\n return null;\n }\n\n if (!('availableResources' in data!)) {\n return null;\n }\n\n const nameMap = new Map<string, string>([\n ['cpuCores', 'CPU cores'],\n ['memorySize', 'Memory size'],\n ['numberOfPods', 'Number of pods'],\n ]);\n return (\n <RequirePermission permission={ocmEntityReadPermission}>\n <TableCardFromData\n data={data.availableResources}\n title=\"Available\"\n nameMap={nameMap}\n />\n </RequirePermission>\n );\n};\n"],"names":[],"mappings":";;;;;;AA2BO,MAAM,+BAA+B,MAAW;AACrD,EAAM,MAAA,EAAE,IAAK,EAAA,GAAI,UAAW,EAAA;AAE5B,EAAA,IAAI,CAAC,IAAM,EAAA;AACT,IAAO,OAAA,IAAA;AAAA;AAGT,EAAI,IAAA,EAAE,wBAAwB,IAAQ,CAAA,EAAA;AACpC,IAAO,OAAA,IAAA;AAAA;AAGT,EAAM,MAAA,OAAA,uBAAc,GAAoB,CAAA;AAAA,IACtC,CAAC,YAAY,WAAW,CAAA;AAAA,IACxB,CAAC,cAAc,aAAa,CAAA;AAAA,IAC5B,CAAC,gBAAgB,gBAAgB;AAAA,GAClC,CAAA;AACD,EACE,uBAAA,KAAA,CAAA,aAAA,CAAC,iBAAkB,EAAA,EAAA,UAAA,EAAY,uBAC7B,EAAA,kBAAA,KAAA,CAAA,aAAA;AAAA,IAAC,iBAAA;AAAA,IAAA;AAAA,MACC,MAAM,IAAK,CAAA,kBAAA;AAAA,MACX,KAAM,EAAA,WAAA;AAAA,MACN;AAAA;AAAA,GAEJ,CAAA;AAEJ;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"ClusterContext.esm.js","sources":["../../../src/components/ClusterContext/ClusterContext.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 */\nimport React, { createContext, useContext, useMemo } from 'react';\nimport useAsyncFn from 'react-use/lib/useAsyncFn';\nimport useDebounce from 'react-use/lib/useDebounce';\n\nimport { useApi } from '@backstage/core-plugin-api';\nimport { ErrorResponseBody } from '@backstage/errors';\nimport { useEntity } from '@backstage/plugin-catalog-react';\n\nimport {\n ANNOTATION_PROVIDER_ID,\n Cluster,\n} from '@backstage-community/plugin-ocm-common';\n\nimport { OcmApiRef } from '../../api';\n\n/**\n * @public\n */\nexport type ClusterContextType = {\n data: Cluster | null;\n loading: boolean;\n error: Error | null;\n};\n\nconst ClusterContext = createContext<ClusterContextType>(\n {} as ClusterContextType,\n);\n\n/**\n * @public\n */\nexport const ClusterContextProvider = (props: any) => {\n const { entity } = useEntity();\n const ocmApi = useApi(OcmApiRef);\n const providerId = entity.metadata.annotations![ANNOTATION_PROVIDER_ID];\n const [{ value: cluster, loading, error: asyncError }, refresh] = useAsyncFn(\n async () => {\n if (providerId) {\n const cl = await ocmApi.getClusterByName(\n providerId,\n entity.metadata.name,\n );\n return cl;\n }\n return null;\n },\n [providerId, entity.metadata.name],\n { loading: true },\n );\n useDebounce(refresh, 10);\n const isError = Boolean(asyncError || (cluster && 'error' in cluster));\n const error = isError\n ? asyncError ||\n Object.assign(new Error((cluster as ErrorResponseBody)?.error?.message), {\n ...(cluster as ErrorResponseBody)?.error,\n })\n : null;\n\n const value = useMemo(\n () => ({\n data: isError || loading ? null : (cluster as Cluster),\n loading,\n error,\n }),\n [cluster, isError, loading, error],\n );\n\n if (!providerId) {\n return <>{props.children}</>;\n }\n\n return (\n <ClusterContext.Provider value={value}>\n {props.children}\n </ClusterContext.Provider>\n );\n};\n\n/**\n * @public\n */\nexport const useCluster = () => useContext(ClusterContext);\n"],"names":[],"mappings":";;;;;;;;AAuCA,MAAM,cAAiB,GAAA,aAAA;AAAA,EACrB,EAAC;AACH,CAAA,CAAA;AAKa,MAAA,sBAAA,GAAyB,CAAC,KAAe,KAAA;AACpD,EAAM,MAAA,EAAE,MAAO,EAAA,GAAI,SAAU,EAAA,CAAA;AAC7B,EAAM,MAAA,MAAA,GAAS,OAAO,SAAS,CAAA,CAAA;AAC/B,EAAA,MAAM,UAAa,GAAA,MAAA,CAAO,QAAS,CAAA,WAAA,CAAa,sBAAsB,CAAA,CAAA;AACtE,EAAM,MAAA,CAAC,EAAE,KAAO,EAAA,OAAA,EAAS,SAAS,KAAO,EAAA,UAAA,EAAc,EAAA,OAAO,CAAI,GAAA,UAAA;AAAA,IAChE,YAAY;AACV,MAAA,IAAI,UAAY,EAAA;AACd,QAAM,MAAA,EAAA,GAAK,MAAM,MAAO,CAAA,gBAAA;AAAA,UACtB,UAAA;AAAA,UACA,OAAO,QAAS,CAAA,IAAA;AAAA,SAClB,CAAA;AACA,QAAO,OAAA,EAAA,CAAA;AAAA,OACT;AACA,MAAO,OAAA,IAAA,CAAA;AAAA,KACT;AAAA,IACA,CAAC,UAAA,EAAY,MAAO,CAAA,QAAA,CAAS,IAAI,CAAA;AAAA,IACjC,EAAE,SAAS,IAAK,EAAA;AAAA,GAClB,CAAA;AACA,EAAA,WAAA,CAAY,SAAS,EAAE,CAAA,CAAA;AACvB,EAAA,MAAM,OAAU,GAAA,OAAA,CAAQ,UAAe,IAAA,OAAA,IAAW,WAAW,OAAQ,CAAA,CAAA;AACrE,EAAM,MAAA,KAAA,GAAQ,OACV,GAAA,UAAA,IACA,MAAO,CAAA,MAAA,CAAO,IAAI,KAAO,CAAA,OAAA,EAA+B,KAAO,EAAA,OAAO,CAAG,EAAA;AAAA,IACvE,GAAI,OAA+B,EAAA,KAAA;AAAA,GACpC,CACD,GAAA,IAAA,CAAA;AAEJ,EAAA,MAAM,KAAQ,GAAA,OAAA;AAAA,IACZ,OAAO;AAAA,MACL,IAAA,EAAM,OAAW,IAAA,OAAA,GAAU,IAAQ,GAAA,OAAA;AAAA,MACnC,OAAA;AAAA,MACA,KAAA;AAAA,KACF,CAAA;AAAA,IACA,CAAC,OAAA,EAAS,OAAS,EAAA,OAAA,EAAS,KAAK,CAAA;AAAA,GACnC,CAAA;AAEA,EAAA,IAAI,CAAC,UAAY,EAAA;AACf,IAAO,uBAAA,KAAA,CAAA,aAAA,CAAA,KAAA,CAAA,QAAA,EAAA,IAAA,EAAG,MAAM,QAAS,CAAA,CAAA;AAAA,GAC3B;AAEA,EAAA,2CACG,cAAe,CAAA,QAAA,EAAf,EAAwB,KAAA,EAAA,EACtB,MAAM,QACT,CAAA,CAAA;AAEJ,EAAA;AAKa,MAAA,UAAA,GAAa,MAAM,UAAA,CAAW,cAAc;;;;"}
1
+ {"version":3,"file":"ClusterContext.esm.js","sources":["../../../src/components/ClusterContext/ClusterContext.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 */\nimport React, { createContext, useContext, useMemo } from 'react';\nimport useAsyncFn from 'react-use/lib/useAsyncFn';\nimport useDebounce from 'react-use/lib/useDebounce';\n\nimport { useApi } from '@backstage/core-plugin-api';\nimport { ErrorResponseBody } from '@backstage/errors';\nimport { useEntity } from '@backstage/plugin-catalog-react';\n\nimport {\n ANNOTATION_PROVIDER_ID,\n Cluster,\n} from '@backstage-community/plugin-ocm-common';\n\nimport { OcmApiRef } from '../../api';\n\n/**\n * @public\n */\nexport type ClusterContextType = {\n data: Cluster | null;\n loading: boolean;\n error: Error | null;\n};\n\nconst ClusterContext = createContext<ClusterContextType>(\n {} as ClusterContextType,\n);\n\n/**\n * @public\n */\nexport const ClusterContextProvider = (props: any) => {\n const { entity } = useEntity();\n const ocmApi = useApi(OcmApiRef);\n const providerId = entity.metadata.annotations![ANNOTATION_PROVIDER_ID];\n const [{ value: cluster, loading, error: asyncError }, refresh] = useAsyncFn(\n async () => {\n if (providerId) {\n const cl = await ocmApi.getClusterByName(\n providerId,\n entity.metadata.name,\n );\n return cl;\n }\n return null;\n },\n [providerId, entity.metadata.name],\n { loading: true },\n );\n useDebounce(refresh, 10);\n const isError = Boolean(asyncError || (cluster && 'error' in cluster));\n const error = isError\n ? asyncError ||\n Object.assign(new Error((cluster as ErrorResponseBody)?.error?.message), {\n ...(cluster as ErrorResponseBody)?.error,\n })\n : null;\n\n const value = useMemo(\n () => ({\n data: isError || loading ? null : (cluster as Cluster),\n loading,\n error,\n }),\n [cluster, isError, loading, error],\n );\n\n if (!providerId) {\n return <>{props.children}</>;\n }\n\n return (\n <ClusterContext.Provider value={value}>\n {props.children}\n </ClusterContext.Provider>\n );\n};\n\n/**\n * @public\n */\nexport const useCluster = () => useContext(ClusterContext);\n"],"names":[],"mappings":";;;;;;;;AAuCA,MAAM,cAAiB,GAAA,aAAA;AAAA,EACrB;AACF,CAAA;AAKa,MAAA,sBAAA,GAAyB,CAAC,KAAe,KAAA;AACpD,EAAM,MAAA,EAAE,MAAO,EAAA,GAAI,SAAU,EAAA;AAC7B,EAAM,MAAA,MAAA,GAAS,OAAO,SAAS,CAAA;AAC/B,EAAA,MAAM,UAAa,GAAA,MAAA,CAAO,QAAS,CAAA,WAAA,CAAa,sBAAsB,CAAA;AACtE,EAAM,MAAA,CAAC,EAAE,KAAO,EAAA,OAAA,EAAS,SAAS,KAAO,EAAA,UAAA,EAAc,EAAA,OAAO,CAAI,GAAA,UAAA;AAAA,IAChE,YAAY;AACV,MAAA,IAAI,UAAY,EAAA;AACd,QAAM,MAAA,EAAA,GAAK,MAAM,MAAO,CAAA,gBAAA;AAAA,UACtB,UAAA;AAAA,UACA,OAAO,QAAS,CAAA;AAAA,SAClB;AACA,QAAO,OAAA,EAAA;AAAA;AAET,MAAO,OAAA,IAAA;AAAA,KACT;AAAA,IACA,CAAC,UAAA,EAAY,MAAO,CAAA,QAAA,CAAS,IAAI,CAAA;AAAA,IACjC,EAAE,SAAS,IAAK;AAAA,GAClB;AACA,EAAA,WAAA,CAAY,SAAS,EAAE,CAAA;AACvB,EAAA,MAAM,OAAU,GAAA,OAAA,CAAQ,UAAe,IAAA,OAAA,IAAW,WAAW,OAAQ,CAAA;AACrE,EAAM,MAAA,KAAA,GAAQ,OACV,GAAA,UAAA,IACA,MAAO,CAAA,MAAA,CAAO,IAAI,KAAO,CAAA,OAAA,EAA+B,KAAO,EAAA,OAAO,CAAG,EAAA;AAAA,IACvE,GAAI,OAA+B,EAAA;AAAA,GACpC,CACD,GAAA,IAAA;AAEJ,EAAA,MAAM,KAAQ,GAAA,OAAA;AAAA,IACZ,OAAO;AAAA,MACL,IAAA,EAAM,OAAW,IAAA,OAAA,GAAU,IAAQ,GAAA,OAAA;AAAA,MACnC,OAAA;AAAA,MACA;AAAA,KACF,CAAA;AAAA,IACA,CAAC,OAAA,EAAS,OAAS,EAAA,OAAA,EAAS,KAAK;AAAA,GACnC;AAEA,EAAA,IAAI,CAAC,UAAY,EAAA;AACf,IAAO,uBAAA,KAAA,CAAA,aAAA,CAAA,KAAA,CAAA,QAAA,EAAA,IAAA,EAAG,MAAM,QAAS,CAAA;AAAA;AAG3B,EAAA,2CACG,cAAe,CAAA,QAAA,EAAf,EAAwB,KAAA,EAAA,EACtB,MAAM,QACT,CAAA;AAEJ;AAKa,MAAA,UAAA,GAAa,MAAM,UAAA,CAAW,cAAc;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"ClusterInfoCard.esm.js","sources":["../../../src/components/ClusterInfoCard/ClusterInfoCard.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 */\nimport React from 'react';\n\nimport { RequirePermission } from '@backstage/plugin-permission-react';\n\nimport { ocmEntityReadPermission } from '@backstage-community/plugin-ocm-common';\n\nimport { useCluster } from '../ClusterContext';\nimport { Status, Update } from '../common';\nimport { TableCardFromData } from '../TableCardFromData';\n\n/**\n * @public\n */\nexport const ClusterInfoCard = () => {\n const { data } = useCluster();\n\n if (!data) {\n return null;\n }\n\n data.openshiftVersion = (\n <Update data={{ version: data.openshiftVersion!, update: data.update! }} />\n ) as any;\n data.status = (<Status status={data.status} />) as any;\n const nameMap = new Map<string, string>([\n ['name', 'Name'],\n ['status', 'Status'],\n ['kubernetesVersion', 'Kubernetes version'],\n ['openshiftId', 'OpenShift ID'],\n ['openshiftVersion', 'OpenShift version'],\n ['platform', 'Platform'],\n ]);\n return (\n <RequirePermission permission={ocmEntityReadPermission}>\n <TableCardFromData data={data} title=\"Cluster Info\" nameMap={nameMap} />\n </RequirePermission>\n );\n};\n"],"names":[],"mappings":";;;;;;;AA4BO,MAAM,kBAAkB,MAAM;AACnC,EAAM,MAAA,EAAE,IAAK,EAAA,GAAI,UAAW,EAAA,CAAA;AAE5B,EAAA,IAAI,CAAC,IAAM,EAAA;AACT,IAAO,OAAA,IAAA,CAAA;AAAA,GACT;AAEA,EAAK,IAAA,CAAA,gBAAA,mBACF,KAAA,CAAA,aAAA,CAAA,MAAA,EAAA,EAAO,IAAM,EAAA,EAAE,OAAS,EAAA,IAAA,CAAK,gBAAmB,EAAA,MAAA,EAAQ,IAAK,CAAA,MAAA,EAAW,EAAA,CAAA,CAAA;AAE3E,EAAA,IAAA,CAAK,MAAU,mBAAA,KAAA,CAAA,aAAA,CAAC,MAAO,EAAA,EAAA,MAAA,EAAQ,KAAK,MAAQ,EAAA,CAAA,CAAA;AAC5C,EAAM,MAAA,OAAA,uBAAc,GAAoB,CAAA;AAAA,IACtC,CAAC,QAAQ,MAAM,CAAA;AAAA,IACf,CAAC,UAAU,QAAQ,CAAA;AAAA,IACnB,CAAC,qBAAqB,oBAAoB,CAAA;AAAA,IAC1C,CAAC,eAAe,cAAc,CAAA;AAAA,IAC9B,CAAC,oBAAoB,mBAAmB,CAAA;AAAA,IACxC,CAAC,YAAY,UAAU,CAAA;AAAA,GACxB,CAAA,CAAA;AACD,EACE,uBAAA,KAAA,CAAA,aAAA,CAAC,iBAAkB,EAAA,EAAA,UAAA,EAAY,uBAC7B,EAAA,kBAAA,KAAA,CAAA,aAAA,CAAC,qBAAkB,IAAY,EAAA,KAAA,EAAM,cAAe,EAAA,OAAA,EAAkB,CACxE,CAAA,CAAA;AAEJ;;;;"}
1
+ {"version":3,"file":"ClusterInfoCard.esm.js","sources":["../../../src/components/ClusterInfoCard/ClusterInfoCard.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 */\nimport React from 'react';\n\nimport { RequirePermission } from '@backstage/plugin-permission-react';\n\nimport { ocmEntityReadPermission } from '@backstage-community/plugin-ocm-common';\n\nimport { useCluster } from '../ClusterContext';\nimport { Status, Update } from '../common';\nimport { TableCardFromData } from '../TableCardFromData';\n\n/**\n * @public\n */\nexport const ClusterInfoCard = () => {\n const { data } = useCluster();\n\n if (!data) {\n return null;\n }\n\n data.openshiftVersion = (\n <Update data={{ version: data.openshiftVersion!, update: data.update! }} />\n ) as any;\n data.status = (<Status status={data.status} />) as any;\n const nameMap = new Map<string, string>([\n ['name', 'Name'],\n ['status', 'Status'],\n ['kubernetesVersion', 'Kubernetes version'],\n ['openshiftId', 'OpenShift ID'],\n ['openshiftVersion', 'OpenShift version'],\n ['platform', 'Platform'],\n ]);\n return (\n <RequirePermission permission={ocmEntityReadPermission}>\n <TableCardFromData data={data} title=\"Cluster Info\" nameMap={nameMap} />\n </RequirePermission>\n );\n};\n"],"names":[],"mappings":";;;;;;;AA4BO,MAAM,kBAAkB,MAAM;AACnC,EAAM,MAAA,EAAE,IAAK,EAAA,GAAI,UAAW,EAAA;AAE5B,EAAA,IAAI,CAAC,IAAM,EAAA;AACT,IAAO,OAAA,IAAA;AAAA;AAGT,EAAK,IAAA,CAAA,gBAAA,mBACF,KAAA,CAAA,aAAA,CAAA,MAAA,EAAA,EAAO,IAAM,EAAA,EAAE,OAAS,EAAA,IAAA,CAAK,gBAAmB,EAAA,MAAA,EAAQ,IAAK,CAAA,MAAA,EAAW,EAAA,CAAA;AAE3E,EAAA,IAAA,CAAK,MAAU,mBAAA,KAAA,CAAA,aAAA,CAAC,MAAO,EAAA,EAAA,MAAA,EAAQ,KAAK,MAAQ,EAAA,CAAA;AAC5C,EAAM,MAAA,OAAA,uBAAc,GAAoB,CAAA;AAAA,IACtC,CAAC,QAAQ,MAAM,CAAA;AAAA,IACf,CAAC,UAAU,QAAQ,CAAA;AAAA,IACnB,CAAC,qBAAqB,oBAAoB,CAAA;AAAA,IAC1C,CAAC,eAAe,cAAc,CAAA;AAAA,IAC9B,CAAC,oBAAoB,mBAAmB,CAAA;AAAA,IACxC,CAAC,YAAY,UAAU;AAAA,GACxB,CAAA;AACD,EACE,uBAAA,KAAA,CAAA,aAAA,CAAC,iBAAkB,EAAA,EAAA,UAAA,EAAY,uBAC7B,EAAA,kBAAA,KAAA,CAAA,aAAA,CAAC,qBAAkB,IAAY,EAAA,KAAA,EAAM,cAAe,EAAA,OAAA,EAAkB,CACxE,CAAA;AAEJ;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"ClusterStatusPage.esm.js","sources":["../../../src/components/ClusterStatusPage/ClusterStatusPage.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 */\nimport React from 'react';\nimport useAsyncFn from 'react-use/lib/useAsyncFn';\nimport useDebounce from 'react-use/lib/useDebounce';\n\nimport {\n CodeSnippet,\n Content,\n Header,\n Page,\n StatusAborted,\n StatusError,\n StatusOK,\n Table,\n WarningPanel,\n} from '@backstage/core-components';\nimport { useApi } from '@backstage/core-plugin-api';\nimport { catalogApiRef, EntityRefLink } from '@backstage/plugin-catalog-react';\nimport { HomePageCompanyLogo } from '@backstage/plugin-home';\nimport { RequirePermission } from '@backstage/plugin-permission-react';\nimport { SearchContextProvider } from '@backstage/plugin-search-react';\n\nimport { Chip, CircularProgress, Grid, makeStyles } from '@material-ui/core';\n\nimport {\n ClusterNodesStatus,\n ClusterOverview,\n ocmClusterReadPermission,\n} from '@backstage-community/plugin-ocm-common';\n\nimport { OcmApiRef } from '../../api';\nimport { ClusterStatusRowData } from '../../types';\nimport { Status, Update } from '../common';\nimport { columns } from './tableHeading';\n\nconst useStylesTwo = makeStyles({\n container: {\n width: '100%',\n },\n});\n\nconst useStyles = makeStyles(theme => ({\n container: {\n margin: theme.spacing(5, 0),\n '& > svg': {\n width: 'auto',\n height: 150,\n },\n },\n}));\n\nconst NodeChip = ({\n count,\n indicatorComponent: IndicatorComponent,\n}: {\n count: number;\n indicatorComponent: React.FC<React.PropsWithChildren<{}>>;\n}) => {\n if (!count) {\n return null;\n }\n return (\n <Chip\n label={<IndicatorComponent>{count}</IndicatorComponent>}\n variant=\"outlined\"\n />\n );\n};\n\nconst NodeChips = ({ nodes }: { nodes: ClusterNodesStatus[] }) => {\n const readyChipsNodes = nodes.filter(node => node.status === 'True').length;\n // TODO: Check if not ready correctly\n const notReadyNodesCount = nodes.filter(\n node => node.status === 'False',\n ).length;\n\n if (nodes.length === 0) {\n return <>-</>;\n }\n\n return (\n <>\n <NodeChip count={readyChipsNodes} indicatorComponent={StatusOK} />\n <NodeChip count={notReadyNodesCount} indicatorComponent={StatusError} />\n <NodeChip\n count={nodes.length - readyChipsNodes - notReadyNodesCount}\n indicatorComponent={StatusAborted}\n />\n </>\n );\n};\n\nconst CatalogClusters = () => {\n const catalogApi = useApi(catalogApiRef);\n const ocmApi = useApi(OcmApiRef);\n const classes = useStylesTwo();\n\n const [{ value: clusterEntities, loading, error }, refresh] = useAsyncFn(\n async () => {\n const clusterResourceEntities = await catalogApi.getEntities({\n filter: { kind: 'Resource', 'spec.type': 'kubernetes-cluster' },\n });\n\n const clusters = await ocmApi.getClusters();\n\n if ('error' in clusters) {\n throw new Error(clusters.error.message);\n }\n\n const clusterEntityMappings = clusterResourceEntities.items.map(\n entity => {\n const cluster = (clusters as ClusterOverview[]).find(\n cd => cd.name === entity.metadata.name,\n );\n return {\n cluster: cluster!,\n entity: entity,\n };\n },\n );\n return clusterEntityMappings;\n },\n [catalogApi],\n { loading: true },\n );\n useDebounce(refresh, 10);\n\n if (error) {\n return (\n <WarningPanel severity=\"error\" title=\"Could not fetch clusters from Hub.\">\n <CodeSnippet language=\"text\" text={error.toString()} />\n </WarningPanel>\n );\n }\n\n if (loading) {\n return <CircularProgress />;\n }\n\n const data: ClusterStatusRowData[] = clusterEntities\n ? clusterEntities.map(ce => {\n return {\n name: (\n <EntityRefLink entityRef={ce.entity}>\n {ce.cluster.name}\n </EntityRefLink>\n ),\n status: <Status status={ce.cluster.status} />,\n infrastructure: ce.cluster.platform,\n version: (\n <Update\n data={{\n version: ce.cluster.openshiftVersion,\n update: ce.cluster.update,\n }}\n />\n ),\n nodes: <NodeChips nodes={ce.cluster.nodes} />,\n };\n })\n : [];\n\n return (\n <div className={classes.container}>\n <Table\n options={{ paging: false }}\n data={data}\n columns={columns}\n title=\"All\"\n />\n </div>\n );\n};\n\nexport const ClusterStatusPage = ({ logo }: { logo?: React.ReactNode }) => {\n const { container } = useStyles();\n\n return (\n <SearchContextProvider>\n <RequirePermission permission={ocmClusterReadPermission}>\n <Page themeId=\"clusters\">\n <Header title=\"Your Managed Clusters\" />\n <Content>\n <Grid container justifyContent=\"center\" spacing={6}>\n {logo && (\n <HomePageCompanyLogo className={container} logo={logo} />\n )}\n <Grid container item xs={12} justifyContent=\"center\">\n <CatalogClusters />\n </Grid>\n </Grid>\n </Content>\n </Page>\n </RequirePermission>\n </SearchContextProvider>\n );\n};\n\nexport default ClusterStatusPage;\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"ClusterStatusPage.esm.js","sources":["../../../src/components/ClusterStatusPage/ClusterStatusPage.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 */\nimport React from 'react';\nimport useAsyncFn from 'react-use/lib/useAsyncFn';\nimport useDebounce from 'react-use/lib/useDebounce';\n\nimport {\n CodeSnippet,\n Content,\n Header,\n Page,\n StatusAborted,\n StatusError,\n StatusOK,\n Table,\n WarningPanel,\n} from '@backstage/core-components';\nimport { useApi } from '@backstage/core-plugin-api';\nimport { catalogApiRef, EntityRefLink } from '@backstage/plugin-catalog-react';\nimport { HomePageCompanyLogo } from '@backstage/plugin-home';\nimport { RequirePermission } from '@backstage/plugin-permission-react';\nimport { SearchContextProvider } from '@backstage/plugin-search-react';\n\nimport { Chip, CircularProgress, Grid, makeStyles } from '@material-ui/core';\n\nimport {\n ClusterNodesStatus,\n ClusterOverview,\n ocmClusterReadPermission,\n} from '@backstage-community/plugin-ocm-common';\n\nimport { OcmApiRef } from '../../api';\nimport { ClusterStatusRowData } from '../../types';\nimport { Status, Update } from '../common';\nimport { columns } from './tableHeading';\n\nconst useStylesTwo = makeStyles({\n container: {\n width: '100%',\n },\n});\n\nconst useStyles = makeStyles(theme => ({\n container: {\n margin: theme.spacing(5, 0),\n '& > svg': {\n width: 'auto',\n height: 150,\n },\n },\n}));\n\nconst NodeChip = ({\n count,\n indicatorComponent: IndicatorComponent,\n}: {\n count: number;\n indicatorComponent: React.FC<React.PropsWithChildren<{}>>;\n}) => {\n if (!count) {\n return null;\n }\n return (\n <Chip\n label={<IndicatorComponent>{count}</IndicatorComponent>}\n variant=\"outlined\"\n />\n );\n};\n\nconst NodeChips = ({ nodes }: { nodes: ClusterNodesStatus[] }) => {\n const readyChipsNodes = nodes.filter(node => node.status === 'True').length;\n // TODO: Check if not ready correctly\n const notReadyNodesCount = nodes.filter(\n node => node.status === 'False',\n ).length;\n\n if (nodes.length === 0) {\n return <>-</>;\n }\n\n return (\n <>\n <NodeChip count={readyChipsNodes} indicatorComponent={StatusOK} />\n <NodeChip count={notReadyNodesCount} indicatorComponent={StatusError} />\n <NodeChip\n count={nodes.length - readyChipsNodes - notReadyNodesCount}\n indicatorComponent={StatusAborted}\n />\n </>\n );\n};\n\nconst CatalogClusters = () => {\n const catalogApi = useApi(catalogApiRef);\n const ocmApi = useApi(OcmApiRef);\n const classes = useStylesTwo();\n\n const [{ value: clusterEntities, loading, error }, refresh] = useAsyncFn(\n async () => {\n const clusterResourceEntities = await catalogApi.getEntities({\n filter: { kind: 'Resource', 'spec.type': 'kubernetes-cluster' },\n });\n\n const clusters = await ocmApi.getClusters();\n\n if ('error' in clusters) {\n throw new Error(clusters.error.message);\n }\n\n const clusterEntityMappings = clusterResourceEntities.items.map(\n entity => {\n const cluster = (clusters as ClusterOverview[]).find(\n cd => cd.name === entity.metadata.name,\n );\n return {\n cluster: cluster!,\n entity: entity,\n };\n },\n );\n return clusterEntityMappings;\n },\n [catalogApi],\n { loading: true },\n );\n useDebounce(refresh, 10);\n\n if (error) {\n return (\n <WarningPanel severity=\"error\" title=\"Could not fetch clusters from Hub.\">\n <CodeSnippet language=\"text\" text={error.toString()} />\n </WarningPanel>\n );\n }\n\n if (loading) {\n return <CircularProgress />;\n }\n\n const data: ClusterStatusRowData[] = clusterEntities\n ? clusterEntities.map(ce => {\n return {\n name: (\n <EntityRefLink entityRef={ce.entity}>\n {ce.cluster.name}\n </EntityRefLink>\n ),\n status: <Status status={ce.cluster.status} />,\n infrastructure: ce.cluster.platform,\n version: (\n <Update\n data={{\n version: ce.cluster.openshiftVersion,\n update: ce.cluster.update,\n }}\n />\n ),\n nodes: <NodeChips nodes={ce.cluster.nodes} />,\n };\n })\n : [];\n\n return (\n <div className={classes.container}>\n <Table\n options={{ paging: false }}\n data={data}\n columns={columns}\n title=\"All\"\n />\n </div>\n );\n};\n\nexport const ClusterStatusPage = ({ logo }: { logo?: React.ReactNode }) => {\n const { container } = useStyles();\n\n return (\n <SearchContextProvider>\n <RequirePermission permission={ocmClusterReadPermission}>\n <Page themeId=\"clusters\">\n <Header title=\"Your Managed Clusters\" />\n <Content>\n <Grid container justifyContent=\"center\" spacing={6}>\n {logo && (\n <HomePageCompanyLogo className={container} logo={logo} />\n )}\n <Grid container item xs={12} justifyContent=\"center\">\n <CatalogClusters />\n </Grid>\n </Grid>\n </Content>\n </Page>\n </RequirePermission>\n </SearchContextProvider>\n );\n};\n\nexport default ClusterStatusPage;\n"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"tableHeading.esm.js","sources":["../../../src/components/ClusterStatusPage/tableHeading.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 */\nimport { TableColumn } from '@backstage/core-components';\n\nimport semver from 'semver';\n\nimport { ClusterStatusRowData } from '../../types';\n\nexport const columns: TableColumn<ClusterStatusRowData>[] = [\n {\n title: 'Name',\n field: 'name',\n highlight: true,\n customSort: (a, b) => {\n // The children type here is actually a ReactNode, but we know it's a string\n return (a.name.props.children as string).localeCompare(\n b.name.props.children as string,\n 'en',\n );\n },\n },\n {\n title: 'Status',\n field: 'status',\n customSort: (a, b) => {\n const availabilityA = a.status.props.status.available;\n const availabilityB = b.status.props.status.available;\n if (availabilityA === availabilityB) return 0;\n return availabilityA ? -1 : 1;\n },\n },\n {\n title: 'Infrastructure',\n field: 'infrastructure',\n },\n {\n title: 'Version',\n field: 'version',\n customSort: (a, b) => {\n return semver.gt(\n a.version.props.data.version,\n b.version.props.data.version,\n )\n ? 1\n : -1;\n },\n },\n {\n title: 'Nodes',\n field: 'nodes',\n customSort: (a, b) => {\n return a.nodes.props.nodes.length - b.nodes.props.nodes.length;\n },\n },\n];\n"],"names":[],"mappings":";;AAqBO,MAAM,OAA+C,GAAA;AAAA,EAC1D;AAAA,IACE,KAAO,EAAA,MAAA;AAAA,IACP,KAAO,EAAA,MAAA;AAAA,IACP,SAAW,EAAA,IAAA;AAAA,IACX,UAAA,EAAY,CAAC,CAAA,EAAG,CAAM,KAAA;AAEpB,MAAQ,OAAA,CAAA,CAAE,IAAK,CAAA,KAAA,CAAM,QAAoB,CAAA,aAAA;AAAA,QACvC,CAAA,CAAE,KAAK,KAAM,CAAA,QAAA;AAAA,QACb,IAAA;AAAA,OACF,CAAA;AAAA,KACF;AAAA,GACF;AAAA,EACA;AAAA,IACE,KAAO,EAAA,QAAA;AAAA,IACP,KAAO,EAAA,QAAA;AAAA,IACP,UAAA,EAAY,CAAC,CAAA,EAAG,CAAM,KAAA;AACpB,MAAA,MAAM,aAAgB,GAAA,CAAA,CAAE,MAAO,CAAA,KAAA,CAAM,MAAO,CAAA,SAAA,CAAA;AAC5C,MAAA,MAAM,aAAgB,GAAA,CAAA,CAAE,MAAO,CAAA,KAAA,CAAM,MAAO,CAAA,SAAA,CAAA;AAC5C,MAAI,IAAA,aAAA,KAAkB,eAAsB,OAAA,CAAA,CAAA;AAC5C,MAAA,OAAO,gBAAgB,CAAK,CAAA,GAAA,CAAA,CAAA;AAAA,KAC9B;AAAA,GACF;AAAA,EACA;AAAA,IACE,KAAO,EAAA,gBAAA;AAAA,IACP,KAAO,EAAA,gBAAA;AAAA,GACT;AAAA,EACA;AAAA,IACE,KAAO,EAAA,SAAA;AAAA,IACP,KAAO,EAAA,SAAA;AAAA,IACP,UAAA,EAAY,CAAC,CAAA,EAAG,CAAM,KAAA;AACpB,MAAA,OAAO,MAAO,CAAA,EAAA;AAAA,QACZ,CAAA,CAAE,OAAQ,CAAA,KAAA,CAAM,IAAK,CAAA,OAAA;AAAA,QACrB,CAAA,CAAE,OAAQ,CAAA,KAAA,CAAM,IAAK,CAAA,OAAA;AAAA,UAEnB,CACA,GAAA,CAAA,CAAA,CAAA;AAAA,KACN;AAAA,GACF;AAAA,EACA;AAAA,IACE,KAAO,EAAA,OAAA;AAAA,IACP,KAAO,EAAA,OAAA;AAAA,IACP,UAAA,EAAY,CAAC,CAAA,EAAG,CAAM,KAAA;AACpB,MAAO,OAAA,CAAA,CAAE,MAAM,KAAM,CAAA,KAAA,CAAM,SAAS,CAAE,CAAA,KAAA,CAAM,MAAM,KAAM,CAAA,MAAA,CAAA;AAAA,KAC1D;AAAA,GACF;AACF;;;;"}
1
+ {"version":3,"file":"tableHeading.esm.js","sources":["../../../src/components/ClusterStatusPage/tableHeading.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 */\nimport { TableColumn } from '@backstage/core-components';\n\nimport semver from 'semver';\n\nimport { ClusterStatusRowData } from '../../types';\n\nexport const columns: TableColumn<ClusterStatusRowData>[] = [\n {\n title: 'Name',\n field: 'name',\n highlight: true,\n customSort: (a, b) => {\n // The children type here is actually a ReactNode, but we know it's a string\n return (a.name.props.children as string).localeCompare(\n b.name.props.children as string,\n 'en',\n );\n },\n },\n {\n title: 'Status',\n field: 'status',\n customSort: (a, b) => {\n const availabilityA = a.status.props.status.available;\n const availabilityB = b.status.props.status.available;\n if (availabilityA === availabilityB) return 0;\n return availabilityA ? -1 : 1;\n },\n },\n {\n title: 'Infrastructure',\n field: 'infrastructure',\n },\n {\n title: 'Version',\n field: 'version',\n customSort: (a, b) => {\n return semver.gt(\n a.version.props.data.version,\n b.version.props.data.version,\n )\n ? 1\n : -1;\n },\n },\n {\n title: 'Nodes',\n field: 'nodes',\n customSort: (a, b) => {\n return a.nodes.props.nodes.length - b.nodes.props.nodes.length;\n },\n },\n];\n"],"names":[],"mappings":";;AAqBO,MAAM,OAA+C,GAAA;AAAA,EAC1D;AAAA,IACE,KAAO,EAAA,MAAA;AAAA,IACP,KAAO,EAAA,MAAA;AAAA,IACP,SAAW,EAAA,IAAA;AAAA,IACX,UAAA,EAAY,CAAC,CAAA,EAAG,CAAM,KAAA;AAEpB,MAAQ,OAAA,CAAA,CAAE,IAAK,CAAA,KAAA,CAAM,QAAoB,CAAA,aAAA;AAAA,QACvC,CAAA,CAAE,KAAK,KAAM,CAAA,QAAA;AAAA,QACb;AAAA,OACF;AAAA;AACF,GACF;AAAA,EACA;AAAA,IACE,KAAO,EAAA,QAAA;AAAA,IACP,KAAO,EAAA,QAAA;AAAA,IACP,UAAA,EAAY,CAAC,CAAA,EAAG,CAAM,KAAA;AACpB,MAAA,MAAM,aAAgB,GAAA,CAAA,CAAE,MAAO,CAAA,KAAA,CAAM,MAAO,CAAA,SAAA;AAC5C,MAAA,MAAM,aAAgB,GAAA,CAAA,CAAE,MAAO,CAAA,KAAA,CAAM,MAAO,CAAA,SAAA;AAC5C,MAAI,IAAA,aAAA,KAAkB,eAAsB,OAAA,CAAA;AAC5C,MAAA,OAAO,gBAAgB,EAAK,GAAA,CAAA;AAAA;AAC9B,GACF;AAAA,EACA;AAAA,IACE,KAAO,EAAA,gBAAA;AAAA,IACP,KAAO,EAAA;AAAA,GACT;AAAA,EACA;AAAA,IACE,KAAO,EAAA,SAAA;AAAA,IACP,KAAO,EAAA,SAAA;AAAA,IACP,UAAA,EAAY,CAAC,CAAA,EAAG,CAAM,KAAA;AACpB,MAAA,OAAO,MAAO,CAAA,EAAA;AAAA,QACZ,CAAA,CAAE,OAAQ,CAAA,KAAA,CAAM,IAAK,CAAA,OAAA;AAAA,QACrB,CAAA,CAAE,OAAQ,CAAA,KAAA,CAAM,IAAK,CAAA;AAAA,UAEnB,CACA,GAAA,EAAA;AAAA;AACN,GACF;AAAA,EACA;AAAA,IACE,KAAO,EAAA,OAAA;AAAA,IACP,KAAO,EAAA,OAAA;AAAA,IACP,UAAA,EAAY,CAAC,CAAA,EAAG,CAAM,KAAA;AACpB,MAAO,OAAA,CAAA,CAAE,MAAM,KAAM,CAAA,KAAA,CAAM,SAAS,CAAE,CAAA,KAAA,CAAM,MAAM,KAAM,CAAA,MAAA;AAAA;AAC1D;AAEJ;;;;"}
@@ -28,7 +28,7 @@ const TableCardFromData = ({
28
28
  const entries = Object.entries(data);
29
29
  nameMap.forEach((_, key) => {
30
30
  const entry = entries.find((e) => e[0] === key);
31
- if (entry === void 0) {
31
+ if (entry === undefined) {
32
32
  return;
33
33
  }
34
34
  parsedData.push({
@@ -1 +1 @@
1
- {"version":3,"file":"TableCardFromData.esm.js","sources":["../../../src/components/TableCardFromData/TableCardFromData.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 */\nimport React from 'react';\n\nimport { Link, Table } from '@backstage/core-components';\n\nimport { Card, CardContent, CardHeader } from '@material-ui/core';\n\nconst convertToGibibytes = (kibibytes: string): string => {\n const sizeInKibibytes = parseInt(\n kibibytes.substring(0, kibibytes.length - 2),\n 10,\n );\n return `${(sizeInKibibytes / 2 ** 20).toFixed(0)} Gi`;\n};\n\nconst valueFormatter = (value: any): any => {\n if (typeof value === 'string') {\n if (value.endsWith('Ki')) {\n return convertToGibibytes(value);\n } else if (value.startsWith('http')) {\n return <Link to={value}>{value}</Link>;\n }\n }\n return value;\n};\n\nexport const TableCardFromData = ({\n data,\n title,\n nameMap,\n}: {\n data: any;\n title: string;\n nameMap: Map<string, string>;\n}) => {\n const parsedData: { name: string; value: any }[] = [];\n const entries = Object.entries(data);\n\n nameMap.forEach((_, key) => {\n const entry = entries.find(e => e[0] === key)!;\n // If key of the map doesn't have an prop in the cluster object, continue\n if (entry === undefined) {\n return;\n }\n parsedData.push({\n // entry[0] === name of the prop\n name: nameMap.get(entry[0])!,\n // entry[1] === value of the prop\n value: valueFormatter(entry[1]),\n });\n });\n\n if (parsedData.length === 0) {\n return null;\n }\n\n return (\n <Card>\n <CardHeader title={title} />\n <CardContent style={{ padding: 0 }}>\n <Table\n options={{\n search: false,\n paging: false,\n toolbar: false,\n header: false,\n padding: 'dense',\n }}\n data={parsedData}\n columns={[\n {\n field: 'name',\n highlight: true,\n width: '15%',\n cellStyle: { whiteSpace: 'nowrap' },\n },\n { field: 'value' },\n ]}\n />\n </CardContent>\n </Card>\n );\n};\n"],"names":[],"mappings":";;;;AAqBA,MAAM,kBAAA,GAAqB,CAAC,SAA8B,KAAA;AACxD,EAAA,MAAM,eAAkB,GAAA,QAAA;AAAA,IACtB,SAAU,CAAA,SAAA,CAAU,CAAG,EAAA,SAAA,CAAU,SAAS,CAAC,CAAA;AAAA,IAC3C,EAAA;AAAA,GACF,CAAA;AACA,EAAA,OAAO,IAAI,eAAkB,GAAA,CAAA,IAAK,EAAI,EAAA,OAAA,CAAQ,CAAC,CAAC,CAAA,GAAA,CAAA,CAAA;AAClD,CAAA,CAAA;AAEA,MAAM,cAAA,GAAiB,CAAC,KAAoB,KAAA;AAC1C,EAAI,IAAA,OAAO,UAAU,QAAU,EAAA;AAC7B,IAAI,IAAA,KAAA,CAAM,QAAS,CAAA,IAAI,CAAG,EAAA;AACxB,MAAA,OAAO,mBAAmB,KAAK,CAAA,CAAA;AAAA,KACtB,MAAA,IAAA,KAAA,CAAM,UAAW,CAAA,MAAM,CAAG,EAAA;AACnC,MAAA,uBAAQ,KAAA,CAAA,aAAA,CAAA,IAAA,EAAA,EAAK,EAAI,EAAA,KAAA,EAAA,EAAQ,KAAM,CAAA,CAAA;AAAA,KACjC;AAAA,GACF;AACA,EAAO,OAAA,KAAA,CAAA;AACT,CAAA,CAAA;AAEO,MAAM,oBAAoB,CAAC;AAAA,EAChC,IAAA;AAAA,EACA,KAAA;AAAA,EACA,OAAA;AACF,CAIM,KAAA;AACJ,EAAA,MAAM,aAA6C,EAAC,CAAA;AACpD,EAAM,MAAA,OAAA,GAAU,MAAO,CAAA,OAAA,CAAQ,IAAI,CAAA,CAAA;AAEnC,EAAQ,OAAA,CAAA,OAAA,CAAQ,CAAC,CAAA,EAAG,GAAQ,KAAA;AAC1B,IAAA,MAAM,QAAQ,OAAQ,CAAA,IAAA,CAAK,OAAK,CAAE,CAAA,CAAC,MAAM,GAAG,CAAA,CAAA;AAE5C,IAAA,IAAI,UAAU,KAAW,CAAA,EAAA;AACvB,MAAA,OAAA;AAAA,KACF;AACA,IAAA,UAAA,CAAW,IAAK,CAAA;AAAA;AAAA,MAEd,IAAM,EAAA,OAAA,CAAQ,GAAI,CAAA,KAAA,CAAM,CAAC,CAAC,CAAA;AAAA;AAAA,MAE1B,KAAO,EAAA,cAAA,CAAe,KAAM,CAAA,CAAC,CAAC,CAAA;AAAA,KAC/B,CAAA,CAAA;AAAA,GACF,CAAA,CAAA;AAED,EAAI,IAAA,UAAA,CAAW,WAAW,CAAG,EAAA;AAC3B,IAAO,OAAA,IAAA,CAAA;AAAA,GACT;AAEA,EAAA,uBACG,KAAA,CAAA,aAAA,CAAA,IAAA,EAAA,IAAA,kBACE,KAAA,CAAA,aAAA,CAAA,UAAA,EAAA,EAAW,KAAc,EAAA,CAAA,kBACzB,KAAA,CAAA,aAAA,CAAA,WAAA,EAAA,EAAY,KAAO,EAAA,EAAE,OAAS,EAAA,CAAA,EAC7B,EAAA,kBAAA,KAAA,CAAA,aAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACC,OAAS,EAAA;AAAA,QACP,MAAQ,EAAA,KAAA;AAAA,QACR,MAAQ,EAAA,KAAA;AAAA,QACR,OAAS,EAAA,KAAA;AAAA,QACT,MAAQ,EAAA,KAAA;AAAA,QACR,OAAS,EAAA,OAAA;AAAA,OACX;AAAA,MACA,IAAM,EAAA,UAAA;AAAA,MACN,OAAS,EAAA;AAAA,QACP;AAAA,UACE,KAAO,EAAA,MAAA;AAAA,UACP,SAAW,EAAA,IAAA;AAAA,UACX,KAAO,EAAA,KAAA;AAAA,UACP,SAAA,EAAW,EAAE,UAAA,EAAY,QAAS,EAAA;AAAA,SACpC;AAAA,QACA,EAAE,OAAO,OAAQ,EAAA;AAAA,OACnB;AAAA,KAAA;AAAA,GAEJ,CACF,CAAA,CAAA;AAEJ;;;;"}
1
+ {"version":3,"file":"TableCardFromData.esm.js","sources":["../../../src/components/TableCardFromData/TableCardFromData.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 */\nimport React from 'react';\n\nimport { Link, Table } from '@backstage/core-components';\n\nimport { Card, CardContent, CardHeader } from '@material-ui/core';\n\nconst convertToGibibytes = (kibibytes: string): string => {\n const sizeInKibibytes = parseInt(\n kibibytes.substring(0, kibibytes.length - 2),\n 10,\n );\n return `${(sizeInKibibytes / 2 ** 20).toFixed(0)} Gi`;\n};\n\nconst valueFormatter = (value: any): any => {\n if (typeof value === 'string') {\n if (value.endsWith('Ki')) {\n return convertToGibibytes(value);\n } else if (value.startsWith('http')) {\n return <Link to={value}>{value}</Link>;\n }\n }\n return value;\n};\n\nexport const TableCardFromData = ({\n data,\n title,\n nameMap,\n}: {\n data: any;\n title: string;\n nameMap: Map<string, string>;\n}) => {\n const parsedData: { name: string; value: any }[] = [];\n const entries = Object.entries(data);\n\n nameMap.forEach((_, key) => {\n const entry = entries.find(e => e[0] === key)!;\n // If key of the map doesn't have an prop in the cluster object, continue\n if (entry === undefined) {\n return;\n }\n parsedData.push({\n // entry[0] === name of the prop\n name: nameMap.get(entry[0])!,\n // entry[1] === value of the prop\n value: valueFormatter(entry[1]),\n });\n });\n\n if (parsedData.length === 0) {\n return null;\n }\n\n return (\n <Card>\n <CardHeader title={title} />\n <CardContent style={{ padding: 0 }}>\n <Table\n options={{\n search: false,\n paging: false,\n toolbar: false,\n header: false,\n padding: 'dense',\n }}\n data={parsedData}\n columns={[\n {\n field: 'name',\n highlight: true,\n width: '15%',\n cellStyle: { whiteSpace: 'nowrap' },\n },\n { field: 'value' },\n ]}\n />\n </CardContent>\n </Card>\n );\n};\n"],"names":[],"mappings":";;;;AAqBA,MAAM,kBAAA,GAAqB,CAAC,SAA8B,KAAA;AACxD,EAAA,MAAM,eAAkB,GAAA,QAAA;AAAA,IACtB,SAAU,CAAA,SAAA,CAAU,CAAG,EAAA,SAAA,CAAU,SAAS,CAAC,CAAA;AAAA,IAC3C;AAAA,GACF;AACA,EAAA,OAAO,IAAI,eAAkB,GAAA,CAAA,IAAK,EAAI,EAAA,OAAA,CAAQ,CAAC,CAAC,CAAA,GAAA,CAAA;AAClD,CAAA;AAEA,MAAM,cAAA,GAAiB,CAAC,KAAoB,KAAA;AAC1C,EAAI,IAAA,OAAO,UAAU,QAAU,EAAA;AAC7B,IAAI,IAAA,KAAA,CAAM,QAAS,CAAA,IAAI,CAAG,EAAA;AACxB,MAAA,OAAO,mBAAmB,KAAK,CAAA;AAAA,KACtB,MAAA,IAAA,KAAA,CAAM,UAAW,CAAA,MAAM,CAAG,EAAA;AACnC,MAAA,uBAAQ,KAAA,CAAA,aAAA,CAAA,IAAA,EAAA,EAAK,EAAI,EAAA,KAAA,EAAA,EAAQ,KAAM,CAAA;AAAA;AACjC;AAEF,EAAO,OAAA,KAAA;AACT,CAAA;AAEO,MAAM,oBAAoB,CAAC;AAAA,EAChC,IAAA;AAAA,EACA,KAAA;AAAA,EACA;AACF,CAIM,KAAA;AACJ,EAAA,MAAM,aAA6C,EAAC;AACpD,EAAM,MAAA,OAAA,GAAU,MAAO,CAAA,OAAA,CAAQ,IAAI,CAAA;AAEnC,EAAQ,OAAA,CAAA,OAAA,CAAQ,CAAC,CAAA,EAAG,GAAQ,KAAA;AAC1B,IAAA,MAAM,QAAQ,OAAQ,CAAA,IAAA,CAAK,OAAK,CAAE,CAAA,CAAC,MAAM,GAAG,CAAA;AAE5C,IAAA,IAAI,UAAU,SAAW,EAAA;AACvB,MAAA;AAAA;AAEF,IAAA,UAAA,CAAW,IAAK,CAAA;AAAA;AAAA,MAEd,IAAM,EAAA,OAAA,CAAQ,GAAI,CAAA,KAAA,CAAM,CAAC,CAAC,CAAA;AAAA;AAAA,MAE1B,KAAO,EAAA,cAAA,CAAe,KAAM,CAAA,CAAC,CAAC;AAAA,KAC/B,CAAA;AAAA,GACF,CAAA;AAED,EAAI,IAAA,UAAA,CAAW,WAAW,CAAG,EAAA;AAC3B,IAAO,OAAA,IAAA;AAAA;AAGT,EAAA,uBACG,KAAA,CAAA,aAAA,CAAA,IAAA,EAAA,IAAA,kBACE,KAAA,CAAA,aAAA,CAAA,UAAA,EAAA,EAAW,KAAc,EAAA,CAAA,kBACzB,KAAA,CAAA,aAAA,CAAA,WAAA,EAAA,EAAY,KAAO,EAAA,EAAE,OAAS,EAAA,CAAA,EAC7B,EAAA,kBAAA,KAAA,CAAA,aAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACC,OAAS,EAAA;AAAA,QACP,MAAQ,EAAA,KAAA;AAAA,QACR,MAAQ,EAAA,KAAA;AAAA,QACR,OAAS,EAAA,KAAA;AAAA,QACT,MAAQ,EAAA,KAAA;AAAA,QACR,OAAS,EAAA;AAAA,OACX;AAAA,MACA,IAAM,EAAA,UAAA;AAAA,MACN,OAAS,EAAA;AAAA,QACP;AAAA,UACE,KAAO,EAAA,MAAA;AAAA,UACP,SAAW,EAAA,IAAA;AAAA,UACX,KAAO,EAAA,KAAA;AAAA,UACP,SAAA,EAAW,EAAE,UAAA,EAAY,QAAS;AAAA,SACpC;AAAA,QACA,EAAE,OAAO,OAAQ;AAAA;AACnB;AAAA,GAEJ,CACF,CAAA;AAEJ;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"common.esm.js","sources":["../../src/components/common.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 */\nimport React from 'react';\n\nimport {\n StatusAborted,\n StatusError,\n StatusOK,\n} from '@backstage/core-components';\n\nimport { Button, Grid, makeStyles, Tooltip } from '@material-ui/core';\nimport ArrowCircleUpIcon from '@mui/icons-material/ArrowCircleUp';\n\nimport { ClusterStatus } from '@backstage-community/plugin-ocm-common';\n\nimport { versionDetails } from '../types';\n\nconst useStyles = makeStyles({\n button: {\n textTransform: 'none',\n borderRadius: 16,\n margin: '0px',\n paddingLeft: '4px',\n paddingRight: '4px',\n },\n});\n\nexport const Status = ({ status }: { status: ClusterStatus }) => {\n if (!status) {\n return <StatusAborted>Unknown</StatusAborted>;\n } else if (status.available) {\n return <StatusOK>Ready</StatusOK>;\n }\n return <StatusError>Not Ready</StatusError>;\n};\n\nexport const Update = ({ data }: { data: versionDetails }) => {\n const classes = useStyles();\n return (\n <>\n {data.update.available ? (\n <Grid container direction=\"column\" spacing={0}>\n <Grid item>{data.version}</Grid>\n <Grid item>\n <Tooltip title={`Version ${data.update.version!} available`}>\n <Button\n variant=\"text\"\n color=\"primary\"\n startIcon={<ArrowCircleUpIcon />}\n className={classes.button}\n href={data.update.url}\n size=\"small\"\n >\n Upgrade available\n </Button>\n </Tooltip>\n </Grid>\n </Grid>\n ) : (\n data.version\n )}\n </>\n );\n};\n"],"names":[],"mappings":";;;;;AA8BA,MAAM,YAAY,UAAW,CAAA;AAAA,EAC3B,MAAQ,EAAA;AAAA,IACN,aAAe,EAAA,MAAA;AAAA,IACf,YAAc,EAAA,EAAA;AAAA,IACd,MAAQ,EAAA,KAAA;AAAA,IACR,WAAa,EAAA,KAAA;AAAA,IACb,YAAc,EAAA,KAAA;AAAA,GAChB;AACF,CAAC,CAAA,CAAA;AAEM,MAAM,MAAS,GAAA,CAAC,EAAE,MAAA,EAAwC,KAAA;AAC/D,EAAA,IAAI,CAAC,MAAQ,EAAA;AACX,IAAO,uBAAA,KAAA,CAAA,aAAA,CAAC,qBAAc,SAAO,CAAA,CAAA;AAAA,GAC/B,MAAA,IAAW,OAAO,SAAW,EAAA;AAC3B,IAAO,uBAAA,KAAA,CAAA,aAAA,CAAC,gBAAS,OAAK,CAAA,CAAA;AAAA,GACxB;AACA,EAAO,uBAAA,KAAA,CAAA,aAAA,CAAC,mBAAY,WAAS,CAAA,CAAA;AAC/B,EAAA;AAEO,MAAM,MAAS,GAAA,CAAC,EAAE,IAAA,EAAqC,KAAA;AAC5D,EAAA,MAAM,UAAU,SAAU,EAAA,CAAA;AAC1B,EAAA,uBAEK,KAAA,CAAA,aAAA,CAAA,KAAA,CAAA,QAAA,EAAA,IAAA,EAAA,IAAA,CAAK,MAAO,CAAA,SAAA,mBACV,KAAA,CAAA,aAAA,CAAA,IAAA,EAAA,EAAK,SAAS,EAAA,IAAA,EAAC,SAAU,EAAA,QAAA,EAAS,OAAS,EAAA,CAAA,EAAA,sCACzC,IAAK,EAAA,EAAA,IAAA,EAAI,IAAE,EAAA,EAAA,IAAA,CAAK,OAAQ,CAAA,kBACxB,KAAA,CAAA,aAAA,CAAA,IAAA,EAAA,EAAK,IAAI,EAAA,IAAA,EAAA,kBACP,KAAA,CAAA,aAAA,CAAA,OAAA,EAAA,EAAQ,KAAO,EAAA,CAAA,QAAA,EAAW,IAAK,CAAA,MAAA,CAAO,OAAQ,CAC7C,UAAA,CAAA,EAAA,kBAAA,KAAA,CAAA,aAAA;AAAA,IAAC,MAAA;AAAA,IAAA;AAAA,MACC,OAAQ,EAAA,MAAA;AAAA,MACR,KAAM,EAAA,SAAA;AAAA,MACN,SAAA,sCAAY,iBAAkB,EAAA,IAAA,CAAA;AAAA,MAC9B,WAAW,OAAQ,CAAA,MAAA;AAAA,MACnB,IAAA,EAAM,KAAK,MAAO,CAAA,GAAA;AAAA,MAClB,IAAK,EAAA,OAAA;AAAA,KAAA;AAAA,IACN,mBAAA;AAAA,GAGH,CACF,CACF,CAAA,GAEA,KAAK,OAET,CAAA,CAAA;AAEJ;;;;"}
1
+ {"version":3,"file":"common.esm.js","sources":["../../src/components/common.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 */\nimport React from 'react';\n\nimport {\n StatusAborted,\n StatusError,\n StatusOK,\n} from '@backstage/core-components';\n\nimport { Button, Grid, makeStyles, Tooltip } from '@material-ui/core';\nimport ArrowCircleUpIcon from '@mui/icons-material/ArrowCircleUp';\n\nimport { ClusterStatus } from '@backstage-community/plugin-ocm-common';\n\nimport { versionDetails } from '../types';\n\nconst useStyles = makeStyles({\n button: {\n textTransform: 'none',\n borderRadius: 16,\n margin: '0px',\n paddingLeft: '4px',\n paddingRight: '4px',\n },\n});\n\nexport const Status = ({ status }: { status: ClusterStatus }) => {\n if (!status) {\n return <StatusAborted>Unknown</StatusAborted>;\n } else if (status.available) {\n return <StatusOK>Ready</StatusOK>;\n }\n return <StatusError>Not Ready</StatusError>;\n};\n\nexport const Update = ({ data }: { data: versionDetails }) => {\n const classes = useStyles();\n return (\n <>\n {data.update.available ? (\n <Grid container direction=\"column\" spacing={0}>\n <Grid item>{data.version}</Grid>\n <Grid item>\n <Tooltip title={`Version ${data.update.version!} available`}>\n <Button\n variant=\"text\"\n color=\"primary\"\n startIcon={<ArrowCircleUpIcon />}\n className={classes.button}\n href={data.update.url}\n size=\"small\"\n >\n Upgrade available\n </Button>\n </Tooltip>\n </Grid>\n </Grid>\n ) : (\n data.version\n )}\n </>\n );\n};\n"],"names":[],"mappings":";;;;;AA8BA,MAAM,YAAY,UAAW,CAAA;AAAA,EAC3B,MAAQ,EAAA;AAAA,IACN,aAAe,EAAA,MAAA;AAAA,IACf,YAAc,EAAA,EAAA;AAAA,IACd,MAAQ,EAAA,KAAA;AAAA,IACR,WAAa,EAAA,KAAA;AAAA,IACb,YAAc,EAAA;AAAA;AAElB,CAAC,CAAA;AAEM,MAAM,MAAS,GAAA,CAAC,EAAE,MAAA,EAAwC,KAAA;AAC/D,EAAA,IAAI,CAAC,MAAQ,EAAA;AACX,IAAO,uBAAA,KAAA,CAAA,aAAA,CAAC,qBAAc,SAAO,CAAA;AAAA,GAC/B,MAAA,IAAW,OAAO,SAAW,EAAA;AAC3B,IAAO,uBAAA,KAAA,CAAA,aAAA,CAAC,gBAAS,OAAK,CAAA;AAAA;AAExB,EAAO,uBAAA,KAAA,CAAA,aAAA,CAAC,mBAAY,WAAS,CAAA;AAC/B;AAEO,MAAM,MAAS,GAAA,CAAC,EAAE,IAAA,EAAqC,KAAA;AAC5D,EAAA,MAAM,UAAU,SAAU,EAAA;AAC1B,EAAA,uBAEK,KAAA,CAAA,aAAA,CAAA,KAAA,CAAA,QAAA,EAAA,IAAA,EAAA,IAAA,CAAK,MAAO,CAAA,SAAA,mBACV,KAAA,CAAA,aAAA,CAAA,IAAA,EAAA,EAAK,SAAS,EAAA,IAAA,EAAC,SAAU,EAAA,QAAA,EAAS,OAAS,EAAA,CAAA,EAAA,sCACzC,IAAK,EAAA,EAAA,IAAA,EAAI,IAAE,EAAA,EAAA,IAAA,CAAK,OAAQ,CAAA,kBACxB,KAAA,CAAA,aAAA,CAAA,IAAA,EAAA,EAAK,IAAI,EAAA,IAAA,EAAA,kBACP,KAAA,CAAA,aAAA,CAAA,OAAA,EAAA,EAAQ,KAAO,EAAA,CAAA,QAAA,EAAW,IAAK,CAAA,MAAA,CAAO,OAAQ,CAC7C,UAAA,CAAA,EAAA,kBAAA,KAAA,CAAA,aAAA;AAAA,IAAC,MAAA;AAAA,IAAA;AAAA,MACC,OAAQ,EAAA,MAAA;AAAA,MACR,KAAM,EAAA,SAAA;AAAA,MACN,SAAA,sCAAY,iBAAkB,EAAA,IAAA,CAAA;AAAA,MAC9B,WAAW,OAAQ,CAAA,MAAA;AAAA,MACnB,IAAA,EAAM,KAAK,MAAO,CAAA,GAAA;AAAA,MAClB,IAAK,EAAA;AAAA,KAAA;AAAA,IACN;AAAA,GAGH,CACF,CACF,CAAA,GAEA,KAAK,OAET,CAAA;AAEJ;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"plugin.esm.js","sources":["../src/plugin.ts"],"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 */\nimport {\n configApiRef,\n createApiFactory,\n createPlugin,\n createRoutableExtension,\n IconComponent,\n identityApiRef,\n} from '@backstage/core-plugin-api';\n\nimport HubOutlinedIcon from '@mui/icons-material/HubOutlined';\n\nimport { OcmApiClient, OcmApiRef } from './api';\nimport { rootRouteRef } from './routes';\n\n/**\n * @public\n */\nexport const ocmPlugin = createPlugin({\n id: 'ocm',\n routes: {\n root: rootRouteRef,\n },\n apis: [\n createApiFactory({\n api: OcmApiRef,\n deps: {\n configApi: configApiRef,\n identityApi: identityApiRef,\n },\n factory: ({ configApi, identityApi }) =>\n new OcmApiClient({ configApi, identityApi }),\n }),\n ],\n});\n\n/**\n * @public\n */\nexport const OcmPage = ocmPlugin.provide(\n createRoutableExtension({\n name: 'OcmPage',\n component: () =>\n import('./components/ClusterStatusPage').then(m => m.ClusterStatusPage),\n mountPoint: rootRouteRef,\n }),\n);\n\n/**\n * @public\n */\nexport const OcmIcon = HubOutlinedIcon as IconComponent;\n"],"names":[],"mappings":";;;;;AAgCO,MAAM,YAAY,YAAa,CAAA;AAAA,EACpC,EAAI,EAAA,KAAA;AAAA,EACJ,MAAQ,EAAA;AAAA,IACN,IAAM,EAAA,YAAA;AAAA,GACR;AAAA,EACA,IAAM,EAAA;AAAA,IACJ,gBAAiB,CAAA;AAAA,MACf,GAAK,EAAA,SAAA;AAAA,MACL,IAAM,EAAA;AAAA,QACJ,SAAW,EAAA,YAAA;AAAA,QACX,WAAa,EAAA,cAAA;AAAA,OACf;AAAA,MACA,OAAA,EAAS,CAAC,EAAE,SAAW,EAAA,WAAA,EACrB,KAAA,IAAI,YAAa,CAAA,EAAE,SAAW,EAAA,WAAA,EAAa,CAAA;AAAA,KAC9C,CAAA;AAAA,GACH;AACF,CAAC,EAAA;AAKM,MAAM,UAAU,SAAU,CAAA,OAAA;AAAA,EAC/B,uBAAwB,CAAA;AAAA,IACtB,IAAM,EAAA,SAAA;AAAA,IACN,SAAA,EAAW,MACT,OAAO,6CAAgC,EAAE,IAAK,CAAA,CAAA,CAAA,KAAK,EAAE,iBAAiB,CAAA;AAAA,IACxE,UAAY,EAAA,YAAA;AAAA,GACb,CAAA;AACH,EAAA;AAKO,MAAM,OAAU,GAAA;;;;"}
1
+ {"version":3,"file":"plugin.esm.js","sources":["../src/plugin.ts"],"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 */\nimport {\n configApiRef,\n createApiFactory,\n createPlugin,\n createRoutableExtension,\n IconComponent,\n identityApiRef,\n} from '@backstage/core-plugin-api';\n\nimport HubOutlinedIcon from '@mui/icons-material/HubOutlined';\n\nimport { OcmApiClient, OcmApiRef } from './api';\nimport { rootRouteRef } from './routes';\n\n/**\n * @public\n */\nexport const ocmPlugin = createPlugin({\n id: 'ocm',\n routes: {\n root: rootRouteRef,\n },\n apis: [\n createApiFactory({\n api: OcmApiRef,\n deps: {\n configApi: configApiRef,\n identityApi: identityApiRef,\n },\n factory: ({ configApi, identityApi }) =>\n new OcmApiClient({ configApi, identityApi }),\n }),\n ],\n});\n\n/**\n * @public\n */\nexport const OcmPage = ocmPlugin.provide(\n createRoutableExtension({\n name: 'OcmPage',\n component: () =>\n import('./components/ClusterStatusPage').then(m => m.ClusterStatusPage),\n mountPoint: rootRouteRef,\n }),\n);\n\n/**\n * @public\n */\nexport const OcmIcon = HubOutlinedIcon as IconComponent;\n"],"names":[],"mappings":";;;;;AAgCO,MAAM,YAAY,YAAa,CAAA;AAAA,EACpC,EAAI,EAAA,KAAA;AAAA,EACJ,MAAQ,EAAA;AAAA,IACN,IAAM,EAAA;AAAA,GACR;AAAA,EACA,IAAM,EAAA;AAAA,IACJ,gBAAiB,CAAA;AAAA,MACf,GAAK,EAAA,SAAA;AAAA,MACL,IAAM,EAAA;AAAA,QACJ,SAAW,EAAA,YAAA;AAAA,QACX,WAAa,EAAA;AAAA,OACf;AAAA,MACA,OAAA,EAAS,CAAC,EAAE,SAAW,EAAA,WAAA,EACrB,KAAA,IAAI,YAAa,CAAA,EAAE,SAAW,EAAA,WAAA,EAAa;AAAA,KAC9C;AAAA;AAEL,CAAC;AAKM,MAAM,UAAU,SAAU,CAAA,OAAA;AAAA,EAC/B,uBAAwB,CAAA;AAAA,IACtB,IAAM,EAAA,SAAA;AAAA,IACN,SAAA,EAAW,MACT,OAAO,6CAAgC,EAAE,IAAK,CAAA,CAAA,CAAA,KAAK,EAAE,iBAAiB,CAAA;AAAA,IACxE,UAAY,EAAA;AAAA,GACb;AACH;AAKO,MAAM,OAAU,GAAA;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"routes.esm.js","sources":["../src/routes.ts"],"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 */\nimport { createRouteRef } from '@backstage/core-plugin-api';\n\nexport const rootRouteRef = createRouteRef({\n id: 'ocm',\n});\n"],"names":[],"mappings":";;AAiBO,MAAM,eAAe,cAAe,CAAA;AAAA,EACzC,EAAI,EAAA,KAAA;AACN,CAAC;;;;"}
1
+ {"version":3,"file":"routes.esm.js","sources":["../src/routes.ts"],"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 */\nimport { createRouteRef } from '@backstage/core-plugin-api';\n\nexport const rootRouteRef = createRouteRef({\n id: 'ocm',\n});\n"],"names":[],"mappings":";;AAiBO,MAAM,eAAe,cAAe,CAAA;AAAA,EACzC,EAAI,EAAA;AACN,CAAC;;;;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@backstage-community/plugin-ocm",
3
- "version": "5.2.5",
3
+ "version": "5.3.0",
4
4
  "main": "dist/index.esm.js",
5
5
  "types": "dist/index.d.ts",
6
6
  "license": "Apache-2.0",
@@ -34,16 +34,16 @@
34
34
  "prettier:fix": "prettier --ignore-unknown --write ."
35
35
  },
36
36
  "dependencies": {
37
- "@backstage-community/plugin-ocm-common": "^3.6.2",
38
- "@backstage/catalog-model": "^1.7.0",
39
- "@backstage/core-components": "^0.15.1",
40
- "@backstage/core-plugin-api": "^1.10.0",
41
- "@backstage/errors": "^1.2.4",
42
- "@backstage/plugin-catalog-react": "^1.14.0",
43
- "@backstage/plugin-home": "^0.8.0",
44
- "@backstage/plugin-permission-react": "^0.4.27",
45
- "@backstage/plugin-search-react": "^1.8.1",
46
- "@backstage/theme": "^0.6.0",
37
+ "@backstage-community/plugin-ocm-common": "^3.7.0",
38
+ "@backstage/catalog-model": "^1.7.3",
39
+ "@backstage/core-components": "^0.16.3",
40
+ "@backstage/core-plugin-api": "^1.10.3",
41
+ "@backstage/errors": "^1.2.7",
42
+ "@backstage/plugin-catalog-react": "^1.15.1",
43
+ "@backstage/plugin-home": "^0.8.4",
44
+ "@backstage/plugin-permission-react": "^0.4.30",
45
+ "@backstage/plugin-search-react": "^1.8.5",
46
+ "@backstage/theme": "^0.6.3",
47
47
  "@material-ui/core": "^4.9.13",
48
48
  "@material-ui/icons": "^4.11.3",
49
49
  "@material-ui/lab": "^4.0.0-alpha.45",
@@ -57,23 +57,23 @@
57
57
  "react-dom": "^16.13.1 || ^17.0.0 || ^18.0.0"
58
58
  },
59
59
  "devDependencies": {
60
- "@backstage/cli": "0.28.2",
61
- "@backstage/core-app-api": "1.15.1",
62
- "@backstage/dev-utils": "1.1.2",
63
- "@backstage/plugin-catalog": "1.24.0",
64
- "@backstage/test-utils": "1.7.0",
60
+ "@backstage/cli": "^0.29.5",
61
+ "@backstage/core-app-api": "^1.15.4",
62
+ "@backstage/dev-utils": "^1.1.6",
63
+ "@backstage/plugin-catalog": "^1.26.1",
64
+ "@backstage/test-utils": "^1.7.4",
65
65
  "@redhat-developer/red-hat-developer-hub-theme": "0.4.0",
66
66
  "@spotify/prettier-config": "^15.0.0",
67
67
  "@testing-library/dom": "^10.0.0",
68
68
  "@testing-library/jest-dom": "^6.0.0",
69
69
  "@testing-library/react": "^15.0.0",
70
70
  "@testing-library/user-event": "14.5.2",
71
- "@types/node": "18.19.64",
71
+ "@types/node": "18.19.68",
72
72
  "@types/react": "^18.2.58",
73
73
  "@types/react-dom": "^18.2.19",
74
74
  "cross-fetch": "4.0.0",
75
75
  "msw": "1.3.5",
76
- "prettier": "3.3.3",
76
+ "prettier": "3.4.2",
77
77
  "react": "^16.13.1 || ^17.0.0 || ^18.0.0",
78
78
  "react-dom": "^16.13.1 || ^17.0.0 || ^18.0.0",
79
79
  "react-router-dom": "^6.0.0"
@@ -99,5 +99,12 @@
99
99
  "@04kash"
100
100
  ],
101
101
  "author": "Red Hat",
102
+ "typesVersions": {
103
+ "*": {
104
+ "index": [
105
+ "dist/index.d.ts"
106
+ ]
107
+ }
108
+ },
102
109
  "module": "./dist/index.esm.js"
103
110
  }