/** * Copyright (c) OpenLens Authors. All rights reserved. * Licensed under MIT License. See LICENSE in root directory for more information. */ import styles from "./cluster-issues.module.scss"; import React from "react"; import { observer } from "mobx-react"; import { computed, makeObservable } from "mobx"; import { Icon } from "../icon"; import { SubHeader } from "../layout/sub-header"; import { Table, TableCell, TableHead, TableRow } from "../table"; import { nodesStore } from "../+nodes/nodes.store"; import { eventStore } from "../+events/event.store"; import { cssNames, prevDefault } from "../../utils"; import type { ItemObject } from "../../../common/item.store"; import { Spinner } from "../spinner"; import { ThemeStore } from "../../theme.store"; import { kubeSelectedUrlParam, toggleDetails } from "../kube-detail-params"; import { apiManager } from "../../../common/k8s-api/api-manager"; import { KubeObjectAge } from "../kube-object/age"; export interface ClusterIssuesProps { className?: string; } interface IWarning extends ItemObject { kind: string; message: string; selfLink: string; renderAge: () => React.ReactElement; ageMs: number; } enum sortBy { type = "type", object = "object", age = "age", } @observer export class ClusterIssues extends React.Component { constructor(props: ClusterIssuesProps) { super(props); makeObservable(this); } @computed get warnings(): IWarning[] { return [ ...nodesStore.items.flatMap(node => ( node.getWarningConditions() .map(({ message }) => ({ selfLink: node.selfLink, getId: node.getId, getName: node.getName, kind: node.kind, message, renderAge: () => , ageMs: -node.getCreationTimestamp(), })) )), ...eventStore.getWarnings().map(warning => ({ getId: () => warning.involvedObject.uid, getName: () => warning.involvedObject.name, renderAge: () => , ageMs: -warning.getCreationTimestamp(), message: warning.message, kind: warning.kind, selfLink: apiManager.lookupApiLink(warning.involvedObject, warning), })), ]; } getTableRow = (uid: string) => { const { warnings } = this; const warning = warnings.find(warn => warn.getId() == uid); const { getId, getName, message, kind, selfLink, renderAge } = warning; return ( toggleDetails(selfLink))} > {message} {getName()} {kind} {renderAge()} ); }; renderContent() { const { warnings } = this; if (!eventStore.isLoaded) { return ( ); } if (!warnings.length) { return (

No issues found

Everything is fine in the Cluster

); } return ( <> Warnings: {warnings.length} warning.kind, [sortBy.object]: warning => warning.getName(), [sortBy.age]: warning => warning.ageMs, }} sortByDefault={{ sortBy: sortBy.object, orderBy: "asc" }} sortSyncWithUrl={false} getTableRow={this.getTableRow} className={cssNames("box grow", ThemeStore.getInstance().activeTheme.type)} > Message Object Type Age
); } render() { return (
{this.renderContent()}
); } }