import "./job-details.scss"; import React from "react"; import kebabCase from "lodash/kebabCase"; import { observer } from "mobx-react"; import { Trans } from "@lingui/macro"; 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 } from "../../navigation"; import { KubeObjectDetailsProps } from "../kube-object"; import { Job, jobApi } from "../../api/endpoints"; import { PodDetailsList } from "../+workloads-pods/pod-details-list"; import { lookupApiLink } from "../../api/kube-api"; import { apiManager } from "../../api/api-manager"; import { KubeObjectMeta } from "../kube-object/kube-object-meta"; interface Props extends KubeObjectDetailsProps { } @observer export class JobDetails extends React.Component { async componentDidMount() { if (!podsStore.isLoaded) { podsStore.loadAll(); } } 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 (
Selector} labelsOnly> { Object.keys(selectors).map(label => ) } {nodeSelector.length > 0 && Node Selector} labelsOnly> { nodeSelector.map(label => ( )) } } {images.length > 0 && Images}> { images.map(image =>

{image}

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

{kind} {name}

); }) }
} Conditions} className="conditions" labelsOnly> {condition && ( )} Completions}> {job.getDesiredCompletions()} Parallelism}> {job.getParallelism()} Pod Status} className="pod-status">
) } } apiManager.registerViews(jobApi, { Details: JobDetails });