mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
92 lines
2.8 KiB
TypeScript
92 lines
2.8 KiB
TypeScript
import "./kube-object-details.scss"
|
|
|
|
import React from "react"
|
|
import { disposeOnUnmount, observer } from "mobx-react";
|
|
import { computed, observable, reaction } from "mobx";
|
|
import { Trans } from "@lingui/macro";
|
|
import { getDetails, hideDetails } from "../../navigation";
|
|
import { Drawer } from "../drawer";
|
|
import { KubeObject } from "../../api/kube-object";
|
|
import { Spinner } from "../spinner";
|
|
import { apiManager, ApiComponents } from "../../api/api-manager";
|
|
import { crdStore } from "../+custom-resources/crd.store";
|
|
import { CrdResourceDetails, CrdResourceMenu } from "../+custom-resources";
|
|
|
|
export interface KubeObjectDetailsProps<T = KubeObject> {
|
|
className?: string;
|
|
object: T;
|
|
}
|
|
|
|
@observer
|
|
export class KubeObjectDetails extends React.Component {
|
|
@observable isLoading = false;
|
|
@observable.ref loadingError: React.ReactNode;
|
|
|
|
@computed get path() {
|
|
return getDetails()
|
|
}
|
|
|
|
@computed get object() {
|
|
const store = apiManager.getStore(this.path);
|
|
if (store) {
|
|
return store.getByPath(this.path);
|
|
}
|
|
}
|
|
|
|
@computed get isCrdInstance() {
|
|
return !!crdStore.getByObject(this.object);
|
|
}
|
|
|
|
@disposeOnUnmount
|
|
loader = reaction(() => [
|
|
this.path,
|
|
this.object, // resource might be updated via watch-event or from already opened details
|
|
crdStore.items.length, // crd stores initialized after loading
|
|
], async () => {
|
|
this.loadingError = ""
|
|
const { path, object } = this;
|
|
if (!object) {
|
|
const store = apiManager.getStore(path);
|
|
if (store) {
|
|
this.isLoading = true
|
|
try {
|
|
await store.loadFromPath(path)
|
|
} catch (err) {
|
|
this.loadingError = <Trans>Resource loading has failed: <b>{err.toString()}</b></Trans>
|
|
} finally {
|
|
this.isLoading = false
|
|
}
|
|
}
|
|
}
|
|
})
|
|
|
|
render() {
|
|
const { object, isLoading, loadingError, isCrdInstance } = this;
|
|
const isOpen = !!(object || isLoading || loadingError);
|
|
let title = "";
|
|
let apiComponents: ApiComponents;
|
|
if (object) {
|
|
const { kind, getName, selfLink } = object;
|
|
title = `${kind}: ${getName()}`;
|
|
apiComponents = apiManager.getViews(selfLink);
|
|
if (isCrdInstance && !apiComponents.Details) {
|
|
apiComponents.Details = CrdResourceDetails
|
|
apiComponents.Menu = CrdResourceMenu
|
|
}
|
|
}
|
|
return (
|
|
<Drawer
|
|
className="KubeObjectDetails flex column"
|
|
open={isOpen}
|
|
title={title}
|
|
toolbar={apiComponents && apiComponents.Menu && <apiComponents.Menu object={object} toolbar/>}
|
|
onClose={hideDetails}
|
|
>
|
|
{isLoading && <Spinner center/>}
|
|
{loadingError && <div className="box center">{loadingError}</div>}
|
|
{apiComponents && apiComponents.Details && <apiComponents.Details object={object}/>}
|
|
</Drawer>
|
|
)
|
|
}
|
|
}
|