mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
* Support Events on CustomResourece details panel Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove unnecessary check Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove legacy KubeObjectMeta use from non-metrics details Signed-off-by: Sebastian Malton <sebastian@malton.name> * Change orderNumber of default KubeMetaDetails Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove last use of legacy global getActiveClusterEntity Signed-off-by: Sebastian Malton <sebastian@malton.name> * Refactor ResourceMetrics to use IAsyncComputed - Introduce first use for namespace metrics Signed-off-by: Sebastian Malton <sebastian@malton.name> * Introduce metrics details item for Ingress Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove legacyStore for nodes Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove legacyStore for ingresses Signed-off-by: Sebastian Malton <sebastian@malton.name> * Replace NodeMetrics in details with injectable Signed-off-by: Sebastian Malton <sebastian@malton.name> * Change namespace metrics details to use more injectables Signed-off-by: Sebastian Malton <sebastian@malton.name> * Change ingress metrics details to use more injectables Signed-off-by: Sebastian Malton <sebastian@malton.name> * Change PersistentVolumeClaim metrics to be injectable Signed-off-by: Sebastian Malton <sebastian@malton.name> * Change DaemonSet metrics to be injectable Signed-off-by: Sebastian Malton <sebastian@malton.name> * Change Deployment metrics to be injectable Signed-off-by: Sebastian Malton <sebastian@malton.name> * Change Job metrics to be injectable Signed-off-by: Sebastian Malton <sebastian@malton.name> * Convert Pod metrics to be injectable Signed-off-by: Sebastian Malton <sebastian@malton.name> * Make ReplicaSet metrics details injectable Signed-off-by: Sebastian Malton <sebastian@malton.name> * Make StatefulSet metrics component injectable Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove dead code Signed-off-by: Sebastian Malton <sebastian@malton.name> * Introduce fix for metrics components visible on all details Signed-off-by: Sebastian Malton <sebastian@malton.name> * Use the new and correct enabled check Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove legacy global for daemonSetStore Signed-off-by: Sebastian Malton <sebastian@malton.name> * Switch components to be static to help with React performance Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove legacy store of CronJobs Signed-off-by: Sebastian Malton <sebastian@malton.name> * Make DeploymentReplicaSets injectable to fix build error Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix up remove dead code Signed-off-by: Sebastian Malton <sebastian@malton.name> * Allow use of ResourceMetrics without IAsyncComputed Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix metrics not updating correctly Signed-off-by: Sebastian Malton <sebastian@malton.name> * Update snapshots because moving KubeObjectMeta out of CustomResourceDetails Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Update more snapshots Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix test failures due to newer dep versions Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix type errors from new asyncComputed Signed-off-by: Sebastian Malton <sebastian@malton.name> Signed-off-by: Sebastian Malton <sebastian@malton.name>
128 lines
4.1 KiB
TypeScript
128 lines
4.1 KiB
TypeScript
/**
|
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
|
*/
|
|
|
|
import "./cronjob-details.scss";
|
|
|
|
import React from "react";
|
|
import kebabCase from "lodash/kebabCase";
|
|
import { disposeOnUnmount, observer } from "mobx-react";
|
|
import { DrawerItem, DrawerTitle } from "../drawer";
|
|
import { Badge } from "../badge/badge";
|
|
import type { JobStore } from "../+workloads-jobs/store";
|
|
import { Link } from "react-router-dom";
|
|
import type { CronJobStore } from "./store";
|
|
import type { KubeObjectDetailsProps } from "../kube-object-details";
|
|
import { getDetailsUrl } from "../kube-detail-params";
|
|
import type { Job } from "../../../common/k8s-api/endpoints";
|
|
import { CronJob } from "../../../common/k8s-api/endpoints";
|
|
import 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 cronJobStoreInjectable from "./store.injectable";
|
|
import jobStoreInjectable from "../+workloads-jobs/store.injectable";
|
|
|
|
export interface CronJobDetailsProps extends KubeObjectDetailsProps<CronJob> {
|
|
}
|
|
|
|
interface Dependencies {
|
|
subscribeStores: SubscribeStores;
|
|
jobStore: JobStore;
|
|
cronJobStore: CronJobStore;
|
|
}
|
|
|
|
@observer
|
|
class NonInjectedCronJobDetails extends React.Component<CronJobDetailsProps & Dependencies> {
|
|
componentDidMount() {
|
|
disposeOnUnmount(this, [
|
|
this.props.subscribeStores([
|
|
this.props.jobStore,
|
|
]),
|
|
]);
|
|
}
|
|
|
|
render() {
|
|
const { object: cronJob, jobStore, cronJobStore } = this.props;
|
|
|
|
if (!cronJob) {
|
|
return null;
|
|
}
|
|
|
|
if (!(cronJob instanceof CronJob)) {
|
|
logger.error("[CronJobDetails]: passed object that is not an instanceof CronJob", cronJob);
|
|
|
|
return null;
|
|
}
|
|
|
|
const childJobs = jobStore.getJobsByOwner(cronJob);
|
|
|
|
return (
|
|
<div className="CronJobDetails">
|
|
<DrawerItem name="Schedule">
|
|
{
|
|
cronJob.isNeverRun()
|
|
? `never (${cronJob.getSchedule()})`
|
|
: cronJob.getSchedule()
|
|
}
|
|
</DrawerItem>
|
|
<DrawerItem name="Active">
|
|
{cronJobStore.getActiveJobsNum(cronJob)}
|
|
</DrawerItem>
|
|
<DrawerItem name="Suspend">
|
|
{cronJob.getSuspendFlag()}
|
|
</DrawerItem>
|
|
<DrawerItem name="Last schedule">
|
|
{cronJob.getLastScheduleTime()}
|
|
</DrawerItem>
|
|
{childJobs.length > 0 && (
|
|
<>
|
|
<DrawerTitle>Jobs</DrawerTitle>
|
|
{childJobs.map((job: Job) => {
|
|
const selectors = job.getSelectors();
|
|
const condition = job.getCondition();
|
|
|
|
return (
|
|
<div className="job" key={job.getId()}>
|
|
<div className="title">
|
|
<Link to={() => job.selfLink ? getDetailsUrl(job.selfLink) : ""}>
|
|
{job.getName()}
|
|
</Link>
|
|
</div>
|
|
<DrawerItem
|
|
name="Condition"
|
|
className="conditions"
|
|
labelsOnly
|
|
>
|
|
{condition && (
|
|
<Badge
|
|
label={condition.type}
|
|
className={kebabCase(condition.type)}
|
|
/>
|
|
)}
|
|
</DrawerItem>
|
|
<DrawerItem name="Selector" labelsOnly>
|
|
{
|
|
selectors.map(label => <Badge key={label} label={label}/>)
|
|
}
|
|
</DrawerItem>
|
|
</div>
|
|
);})
|
|
}
|
|
</>
|
|
)}
|
|
</div>
|
|
);
|
|
}
|
|
}
|
|
|
|
export const CronJobDetails = withInjectables<Dependencies, CronJobDetailsProps>(NonInjectedCronJobDetails, {
|
|
getProps: (di, props) => ({
|
|
...props,
|
|
subscribeStores: di.inject(subscribeStoresInjectable),
|
|
cronJobStore: di.inject(cronJobStoreInjectable),
|
|
jobStore: di.inject(jobStoreInjectable),
|
|
}),
|
|
});
|