import "./job-details.scss"; import React from "react"; import kebabCase from "lodash/kebabCase"; import { observer } from "mobx-react"; import { DrawerItem } from "../drawer"; import { Badge } from "../badge"; import { PodDetailsStatuses } from "../+workloads-pods/pod-details-statuses"; import { Link } from "react-router-dom"; import { PodDetailsTolerations } from "../+workloads-pods/pod-details-tolerations"; import { PodDetailsAffinities } from "../+workloads-pods/pod-details-affinities"; import { KubeEventDetails } from "../+events/kube-event-details"; import { podsStore } from "../+workloads-pods/pods.store"; import { jobStore } from "./job.store"; import { getDetailsUrl, KubeObjectDetailsProps } from "../kube-object"; import { Job } from "../../api/endpoints"; import { PodDetailsList } from "../+workloads-pods/pod-details-list"; import { lookupApiLink } from "../../api/kube-api"; import { KubeObjectMeta } from "../kube-object/kube-object-meta"; import { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry"; interface Props extends KubeObjectDetailsProps { } @observer export class JobDetails extends React.Component { async componentDidMount() { podsStore.reloadAll(); } render() { const { object: job } = this.props; if (!job) return null; const selectors = job.getSelectors(); const nodeSelector = job.getNodeSelectors(); const images = job.getImages(); const childPods = jobStore.getChildPods(job); const ownerRefs = job.getOwnerRefs(); const condition = job.getCondition(); return (
{ Object.keys(selectors).map(label => ) } {nodeSelector.length > 0 && { nodeSelector.map(label => ( )) } } {images.length > 0 && { images.map(image =>

{image}

) }
} {ownerRefs.length > 0 && { ownerRefs.map(ref => { const { name, kind } = ref; const detailsUrl = getDetailsUrl(lookupApiLink(ref, job)); return (

{kind} {name}

); }) }
} {condition && ( )} {job.getDesiredCompletions()} {job.getParallelism()}
); } } kubeObjectDetailRegistry.add({ kind: "Job", apiVersions: ["batch/v1"], components: { Details: (props: any) => } }); kubeObjectDetailRegistry.add({ kind: "Job", apiVersions: ["batch/v1"], priority: 5, components: { Details: (props: any) => } });