/** * Copyright (c) OpenLens Authors. All rights reserved. * Licensed under MIT License. See LICENSE in root directory for more information. */ import "./job-details.scss"; import React from "react"; import kebabCase from "lodash/kebabCase"; import { disposeOnUnmount, observer } from "mobx-react"; import { DrawerItem } from "../drawer"; import { Badge } from "../badge"; import { PodDetailsStatuses } from "../+workloads-pods/pod-details-statuses"; import { PodDetailsTolerations } from "../+workloads-pods/pod-details-tolerations"; import { PodDetailsAffinities } from "../+workloads-pods/pod-details-affinities"; import type { JobStore } from "./store"; import type { KubeObjectDetailsProps } from "../kube-object-details"; import { Job } from "../../../common/k8s-api/endpoints"; import { PodDetailsList } from "../+workloads-pods/pod-details-list"; import type { Logger } from "../../../common/logger"; import { withInjectables } from "@ogre-tools/injectable-react"; import type { SubscribeStores } from "../../kube-watch-api/kube-watch-api"; import subscribeStoresInjectable from "../../kube-watch-api/subscribe-stores.injectable"; import type { PodStore } from "../+workloads-pods/store"; import podStoreInjectable from "../+workloads-pods/store.injectable"; import jobStoreInjectable from "./store.injectable"; import loggerInjectable from "../../../common/logger.injectable"; export interface JobDetailsProps extends KubeObjectDetailsProps { } interface Dependencies { subscribeStores: SubscribeStores; podStore: PodStore; jobStore: JobStore; logger: Logger; } @observer class NonInjectedJobDetails extends React.Component { componentDidMount() { disposeOnUnmount(this, [ this.props.subscribeStores([ this.props.podStore, ]), ]); } render() { const { object: job, jobStore, logger } = this.props; if (!job) { return null; } if (!(job instanceof Job)) { logger.error("[JobDetails]: passed object that is not an instanceof Job", job); return null; } const selectors = job.getSelectors(); const nodeSelector = job.getNodeSelectors(); const images = job.getImages(); const childPods = jobStore.getChildPods(job); const condition = job.getCondition(); return (
{ Object.keys(selectors).map(label => ) } {nodeSelector.length > 0 && ( { nodeSelector.map(label => ( )) } )} {images.length > 0 && ( { images.map(image =>

{image}

) }
)} {condition && ( )} {job.getDesiredCompletions()} {job.getParallelism()}
); } } export const JobDetails = withInjectables(NonInjectedJobDetails, { getProps: (di, props) => ({ ...props, subscribeStores: di.inject(subscribeStoresInjectable), podStore: di.inject(podStoreInjectable), jobStore: di.inject(jobStoreInjectable), logger: di.inject(loggerInjectable), }), });