1
0
mirror of https://github.com/lensapp/lens.git synced 2025-05-20 05:10:56 +00:00

Cleanup PodDetailsContainer

- Use DrawerItem.props.hidden more

- Display Command and Arguments in a monospace list instead of joined to
  make it easier to read

Signed-off-by: Sebastian Malton <sebastian@malton.name>
This commit is contained in:
Sebastian Malton 2021-11-10 15:27:45 -05:00
parent de4c7e4cff
commit 795c8f6e3d
2 changed files with 91 additions and 92 deletions

View File

@ -58,4 +58,11 @@
@include pod-status-colors; @include pod-status-colors;
} }
ul.argument-list {
li {
font-family: monospace;
word-break: break-all;
}
}
} }

View File

@ -44,6 +44,8 @@ interface Props {
metrics?: { [key: string]: IMetrics }; metrics?: { [key: string]: IMetrics };
} }
const hiddenPullPolicy = "IfNotPresent";
@observer @observer
export class PodDetailsContainer extends React.Component<Props> { export class PodDetailsContainer extends React.Component<Props> {
@ -54,36 +56,42 @@ export class PodDetailsContainer extends React.Component<Props> {
} }
renderStatus(state: string, status: IPodContainerStatus) { renderStatus(state: string, status: IPodContainerStatus) {
const ready = status ? status.ready : ""; if (!state || !status) {
return null;
}
return ( return (
<span className={cssNames("status", state)}> <DrawerItem name="Status">
{state}{ready ? `, ready` : ""} <span className={cssNames("status", state)}>
{state === "terminated" ? ` - ${status.state.terminated.reason} (exit code: ${status.state.terminated.exitCode})` : ""} {state}{status.ready ? `, ready` : ""}
</span> {state === "terminated" ? ` - ${status.state.terminated.reason} (exit code: ${status.state.terminated.exitCode})` : ""}
</span>
</DrawerItem>
); );
} }
renderLastState(lastState: string, status: IPodContainerStatus) { renderLastState(lastState: string, status: IPodContainerStatus) {
if (lastState === "terminated") { if (lastState !== "terminated" || !status) {
return ( return null;
}
return (
<DrawerItem name="Last Status">
<span> <span>
{lastState}<br/> {lastState}<br/>
Reason: {status.lastState.terminated.reason} - exit code: {status.lastState.terminated.exitCode}<br/> Reason: {status.lastState.terminated.reason} - exit code: {status.lastState.terminated.exitCode}<br/>
Started at: {<LocaleDate date={status.lastState.terminated.startedAt} />}<br/> Started at: {<LocaleDate date={status.lastState.terminated.startedAt} />}<br/>
Finished at: {<LocaleDate date={status.lastState.terminated.finishedAt} />}<br/> Finished at: {<LocaleDate date={status.lastState.terminated.finishedAt} />}<br/>
</span> </span>
); </DrawerItem>
} );
return null;
} }
render() { render() {
const { pod, container, metrics } = this.props; const { pod, container, metrics } = this.props;
if (!pod || !container) return null; if (!pod || !container) return null;
const { name, image, imagePullPolicy, ports, volumeMounts, command, args } = container; const { name, image, imagePullPolicy = hiddenPullPolicy, ports = [], volumeMounts = [], command = [], args = [] } = container;
const status = pod.getContainerStatuses().find(status => status.name === container.name); const status = pod.getContainerStatuses().find(status => status.name === container.name);
const state = status ? Object.keys(status.state)[0] : ""; const state = status ? Object.keys(status.state)[0] : "";
const lastState = status ? Object.keys(status.lastState)[0] : ""; const lastState = status ? Object.keys(status.lastState)[0] : "";
@ -105,97 +113,81 @@ export class PodDetailsContainer extends React.Component<Props> {
<div className="pod-container-title"> <div className="pod-container-title">
<StatusBrick className={cssNames(state, { ready })}/>{name} <StatusBrick className={cssNames(state, { ready })}/>{name}
</div> </div>
{!isMetricHidden && !isInitContainer && {!isMetricHidden && !isInitContainer && (
<ResourceMetrics tabs={metricTabs} params={{ metrics }}> <ResourceMetrics tabs={metricTabs} params={{ metrics }}>
<ContainerCharts/> <ContainerCharts/>
</ResourceMetrics> </ResourceMetrics>
} )}
{status &&
<DrawerItem name="Status"> {this.renderStatus(state, status)}
{this.renderStatus(state, status)} {this.renderLastState(lastState, status)}
</DrawerItem>
}
{lastState &&
<DrawerItem name="Last Status">
{this.renderLastState(lastState, status)}
</DrawerItem>
}
<DrawerItem name="Image"> <DrawerItem name="Image">
<Badge label={image} tooltip={imageId}/> <Badge label={image} tooltip={imageId}/>
</DrawerItem> </DrawerItem>
{imagePullPolicy && imagePullPolicy !== "IfNotPresent" &&
<DrawerItem name="ImagePullPolicy"> <DrawerItem name="ImagePullPolicy" hidden={imagePullPolicy === hiddenPullPolicy}>
{imagePullPolicy} {imagePullPolicy}
</DrawerItem> </DrawerItem>
}
{ports && ports.length > 0 &&
<DrawerItem name="Ports">
{
ports.map((port) => {
const key = `${container.name}-port-${port.containerPort}-${port.protocol}`;
return ( <DrawerItem name="Ports" hidden={ports.length === 0}>
<PodContainerPort pod={pod} port={port} key={key}/>
);
})
}
</DrawerItem>
}
{<ContainerEnvironment container={container} namespace={pod.getNs()}/>}
{volumeMounts && volumeMounts.length > 0 &&
<DrawerItem name="Mounts">
{ {
volumeMounts.map(mount => { ports.map((port) => (
const { name, mountPath, readOnly } = mount; <PodContainerPort
pod={pod}
return ( port={port}
<React.Fragment key={name + mountPath}> key={`${container.name}-port-${port.containerPort}-${port.protocol}`}
<span className="mount-path">{mountPath}</span> />
<span className="mount-from">from {name} ({readOnly ? "ro" : "rw"})</span>
</React.Fragment>
);
})
}
</DrawerItem>
}
{liveness.length > 0 &&
<DrawerItem name="Liveness" labelsOnly>
{
liveness.map((value, index) => (
<Badge key={index} label={value}/>
)) ))
} }
</DrawerItem> </DrawerItem>
}
{readiness.length > 0 &&
<DrawerItem name="Readiness" labelsOnly>
{
readiness.map((value, index) => (
<Badge key={index} label={value}/>
))
}
</DrawerItem>
}
{startup.length > 0 &&
<DrawerItem name="Startup" labelsOnly>
{
startup.map((value, index) => (
<Badge key={index} label={value}/>
))
}
</DrawerItem>
}
{command &&
<DrawerItem name="Command">
{command.join(" ")}
</DrawerItem>
}
{args && <ContainerEnvironment container={container} namespace={pod.getNs()}/>
<DrawerItem name="Arguments">
{args.join(" ")} <DrawerItem name="Mounts" hidden={volumeMounts.length === 0}>
{
volumeMounts.map(({ name, mountPath, readOnly }) => (
<React.Fragment key={name + mountPath}>
<span className="mount-path">{mountPath}</span>
<span className="mount-from">from {name} ({readOnly ? "ro" : "rw"})</span>
</React.Fragment>
))
}
</DrawerItem>
<DrawerItem name="Liveness" labelsOnly hidden={liveness.length === 0}>
{
liveness.map((value, index) => <Badge key={index} label={value}/>)
}
</DrawerItem>
<DrawerItem name="Readiness" labelsOnly hidden={readiness.length === 0}>
{
readiness.map((value, index) => <Badge key={index} label={value}/>)
}
</DrawerItem>
<DrawerItem name="Startup" labelsOnly hidden={startup.length === 0}>
{
startup.map((value, index) => <Badge key={index} label={value}/>)
}
</DrawerItem>
<DrawerItem name="Command" hidden={command.length === 0}>
<ul className="argument-list">
{
command.map((cmd, index) => <li key={index}>{cmd}</li>)
}
</ul>
</DrawerItem>
<DrawerItem name="Arguments" hidden={args.length === 0}>
<ul className="argument-list">
{
args.map((arg, index) => <li key={index}>{arg}</li>)
}
</ul>
</DrawerItem> </DrawerItem>
}
</div> </div>
); );
} }