1
0
mirror of https://github.com/lensapp/lens.git synced 2025-05-20 05:10:56 +00:00
lens/dashboard/client/components/+workloads-pods/pod-details-affinities.tsx
Sebastian Malton b1ff34879a cleanup Lens repo with tighter linting
Signed-off-by: Sebastian Malton <smalton@mirantis.com>
2020-07-09 17:00:23 -04:00

36 lines
1.1 KiB
TypeScript

import "./pod-details-affinities.scss";
import * as React from "react";
import jsYaml from "js-yaml";
import { Trans } from "@lingui/macro";
import { AceEditor } from "../ace-editor";
import { DrawerParamToggler, DrawerItem } from "../drawer";
import { Pod, Deployment, DaemonSet, StatefulSet, ReplicaSet, Job } from "../../api/endpoints";
interface Props {
workload: Pod | Deployment | DaemonSet | StatefulSet | ReplicaSet | Job;
}
export class PodDetailsAffinities extends React.Component<Props> {
render(): JSX.Element {
const { workload } = this.props;
const affinitiesNum = workload.getAffinityNumber();
const affinities = workload.getAffinity();
if (!affinitiesNum) {
return null;
}
return (
<DrawerItem name={<Trans>Affinities</Trans>} className="PodDetailsAffinities">
<DrawerParamToggler label={affinitiesNum}>
<div className="ace-container">
<AceEditor
mode="yaml"
value={jsYaml.dump(affinities)}
showGutter={false}
readOnly
/>
</div>
</DrawerParamToggler>
</DrawerItem>
);
}
}