import "./pods.scss" import React, { Fragment } from "react"; import { observer } from "mobx-react"; import { Link } from "react-router-dom"; import { Trans } from "@lingui/macro"; import { podsStore } from "./pods.store"; import { RouteComponentProps } from "react-router"; import { volumeClaimStore } from "../+storage-volume-claims/volume-claim.store"; import { IPodsRouteParams } from "../+workloads"; import { eventStore } from "../+events/event.store"; import { KubeObjectListLayout } from "../kube-object"; import { Pod } from "../../api/endpoints"; import { StatusBrick } from "../status-brick"; import { cssNames, stopPropagation } from "../../utils"; import { getDetailsUrl } from "../../navigation"; import toPairs from "lodash/toPairs"; import startCase from "lodash/startCase"; import kebabCase from "lodash/kebabCase"; import { lookupApiLink } from "../../api/kube-api"; import { KubeObjectStatusIcon } from "../kube-object-status-icon"; enum sortBy { name = "name", namespace = "namespace", containers = "containers", restarts = "restarts", age = "age", qos = "qos", owners = "owners", status = "status", } interface Props extends RouteComponentProps { } @observer export class Pods extends React.Component { renderContainersStatus(pod: Pod) { return pod.getContainerStatuses().map(containerStatus => { const { name, state, ready } = containerStatus; return ( (
{name} ({status}{ready ? ", ready" : ""})
{toPairs(state[status]).map(([name, value]) => (
{startCase(name)}
{value}
))}
)) }} />
) }); } render() { return ( pod.getName(), [sortBy.namespace]: (pod: Pod) => pod.getNs(), [sortBy.containers]: (pod: Pod) => pod.getContainers().length, [sortBy.restarts]: (pod: Pod) => pod.getRestartsCount(), [sortBy.owners]: (pod: Pod) => pod.getOwnerRefs().map(ref => ref.kind), [sortBy.qos]: (pod: Pod) => pod.getQosClass(), [sortBy.age]: (pod: Pod) => pod.metadata.creationTimestamp, [sortBy.status]: (pod: Pod) => pod.getStatusMessage(), }} searchFilters={[ (pod: Pod) => pod.getSearchFields(), (pod: Pod) => pod.getStatusMessage(), (pod: Pod) => pod.status.podIP, ]} renderHeaderTitle={Pods} renderTableHeader={[ { title: Name, className: "name", sortBy: sortBy.name }, { className: "warning" }, { title: Namespace, className: "namespace", sortBy: sortBy.namespace }, { title: Containers, className: "containers", sortBy: sortBy.containers }, { title: Restarts, className: "restarts", sortBy: sortBy.restarts }, { title: Controlled By, className: "owners", sortBy: sortBy.owners }, { title: QoS, className: "qos", sortBy: sortBy.qos }, { title: Age, className: "age", sortBy: sortBy.age }, { title: Status, className: "status", sortBy: sortBy.status }, ]} renderTableContents={(pod: Pod) => [ pod.getName(), , pod.getNs(), this.renderContainersStatus(pod), pod.getRestartsCount(), pod.getOwnerRefs().map(ref => { const { kind, name } = ref; const detailsLink = getDetailsUrl(lookupApiLink(ref, pod)); return ( {kind} ) }), pod.getQosClass(), pod.getAge(), { title: pod.getStatusMessage(), className: kebabCase(pod.getStatusMessage()) } ]} /> ) } }