mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
* decentralizing page url-params management -- PoC / tsc 4.1 random fixes Signed-off-by: Roman <ixrock@gmail.com> * fixes, tweak example-extension for demo Signed-off-by: Roman <ixrock@gmail.com> * lint fixes, revert tests Signed-off-by: Roman <ixrock@gmail.com> * removed occasional changes related to typescript 4.1 Signed-off-by: Roman <ixrock@gmail.com> * updated example with 2 menu-items targeting same page with different params Signed-off-by: Roman <ixrock@gmail.com> * fix: merge page url chunks with native URL()-api, simplified default page-params registration Signed-off-by: Roman <ixrock@gmail.com> * fix: make lint happy Signed-off-by: Roman <ixrock@gmail.com> * fix: unit-tests Signed-off-by: Roman <ixrock@gmail.com> * renaming by jim's request: UrlParam => PageParam (type), createUrlParam => createPageParam (helper) Signed-off-by: Roman <ixrock@gmail.com> * fix: reverting NamespaceStore public-api breaking changes Signed-off-by: Roman <ixrock@gmail.com> * lint fix Signed-off-by: Roman <ixrock@gmail.com> * fine-tuning Signed-off-by: Roman <ixrock@gmail.com> * yes, lint always unhappy Signed-off-by: Roman <ixrock@gmail.com> * fix build Signed-off-by: Roman <ixrock@gmail.com> * small fixes Signed-off-by: Roman <ixrock@gmail.com> * fix merge-conflicts Signed-off-by: Roman <ixrock@gmail.com> * removed `isSystem` page-param's init field exposed to extensions-api Signed-off-by: Roman <ixrock@gmail.com>
112 lines
3.6 KiB
TypeScript
112 lines
3.6 KiB
TypeScript
import "./volume-claim-details.scss";
|
|
|
|
import React, { Fragment } from "react";
|
|
import { reaction } from "mobx";
|
|
import { disposeOnUnmount, observer } from "mobx-react";
|
|
import { t, Trans } from "@lingui/macro";
|
|
import { DrawerItem, DrawerTitle } from "../drawer";
|
|
import { Badge } from "../badge";
|
|
import { podsStore } from "../+workloads-pods/pods.store";
|
|
import { Link } from "react-router-dom";
|
|
import { KubeEventDetails } from "../+events/kube-event-details";
|
|
import { volumeClaimStore } from "./volume-claim.store";
|
|
import { ResourceMetrics } from "../resource-metrics";
|
|
import { VolumeClaimDiskChart } from "./volume-claim-disk-chart";
|
|
import { getDetailsUrl, KubeObjectDetailsProps, KubeObjectMeta } from "../kube-object";
|
|
import { PersistentVolumeClaim } from "../../api/endpoints";
|
|
import { _i18n } from "../../i18n";
|
|
import { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry";
|
|
|
|
interface Props extends KubeObjectDetailsProps<PersistentVolumeClaim> {
|
|
}
|
|
|
|
@observer
|
|
export class PersistentVolumeClaimDetails extends React.Component<Props> {
|
|
@disposeOnUnmount
|
|
clean = reaction(() => this.props.object, () => {
|
|
volumeClaimStore.reset();
|
|
});
|
|
|
|
componentWillUnmount() {
|
|
volumeClaimStore.reset();
|
|
}
|
|
|
|
render() {
|
|
const { object: volumeClaim } = this.props;
|
|
|
|
if (!volumeClaim) {
|
|
return null;
|
|
}
|
|
const { storageClassName, accessModes } = volumeClaim.spec;
|
|
const { metrics } = volumeClaimStore;
|
|
const pods = volumeClaim.getPods(podsStore.items);
|
|
const metricTabs = [
|
|
<Trans key="disk">Disk</Trans>
|
|
];
|
|
|
|
return (
|
|
<div className="PersistentVolumeClaimDetails">
|
|
<ResourceMetrics
|
|
loader={() => volumeClaimStore.loadMetrics(volumeClaim)}
|
|
tabs={metricTabs} object={volumeClaim} params={{ metrics }}
|
|
>
|
|
<VolumeClaimDiskChart/>
|
|
</ResourceMetrics>
|
|
<KubeObjectMeta object={volumeClaim}/>
|
|
<DrawerItem name={<Trans>Access Modes</Trans>}>
|
|
{accessModes.join(", ")}
|
|
</DrawerItem>
|
|
<DrawerItem name={<Trans>Storage Class Name</Trans>}>
|
|
{storageClassName}
|
|
</DrawerItem>
|
|
<DrawerItem name={<Trans>Storage</Trans>}>
|
|
{volumeClaim.getStorage()}
|
|
</DrawerItem>
|
|
<DrawerItem name={<Trans>Pods</Trans>} className="pods">
|
|
{pods.map(pod => (
|
|
<Link key={pod.getId()} to={getDetailsUrl(pod.selfLink)}>
|
|
{pod.getName()}
|
|
</Link>
|
|
))}
|
|
</DrawerItem>
|
|
<DrawerItem name={<Trans>Status</Trans>}>
|
|
{volumeClaim.getStatus()}
|
|
</DrawerItem>
|
|
|
|
<DrawerTitle title={_i18n._(t`Selector`)}/>
|
|
|
|
<DrawerItem name={<Trans>Match Labels</Trans>} labelsOnly>
|
|
{volumeClaim.getMatchLabels().map(label => <Badge key={label} label={label}/>)}
|
|
</DrawerItem>
|
|
|
|
<DrawerItem name={<Trans>Match Expressions</Trans>}>
|
|
{volumeClaim.getMatchExpressions().map(({ key, operator, values }, i) => (
|
|
<Fragment key={i}>
|
|
<DrawerItem name={<Trans>Key</Trans>}>{key}</DrawerItem>
|
|
<DrawerItem name={<Trans>Operator</Trans>}>{operator}</DrawerItem>
|
|
<DrawerItem name={<Trans>Values</Trans>}>{values.join(", ")}</DrawerItem>
|
|
</Fragment>
|
|
))}
|
|
</DrawerItem>
|
|
</div>
|
|
);
|
|
}
|
|
}
|
|
|
|
kubeObjectDetailRegistry.add({
|
|
kind: "PersistentVolumeClaim",
|
|
apiVersions: ["v1"],
|
|
components: {
|
|
Details: (props) => <PersistentVolumeClaimDetails {...props} />
|
|
}
|
|
});
|
|
|
|
kubeObjectDetailRegistry.add({
|
|
kind: "PersistentVolumeClaim",
|
|
apiVersions: ["v1"],
|
|
priority: 5,
|
|
components: {
|
|
Details: (props) => <KubeEventDetails {...props} />
|
|
}
|
|
});
|