1
0
mirror of https://github.com/lensapp/lens.git synced 2025-05-20 05:10:56 +00:00
lens/src/renderer/components/+events/kube-event-details.tsx
Sebastian Malton ade0775061 Remove all usages of legacy global logger
Signed-off-by: Sebastian Malton <sebastian@malton.name>
2023-01-05 13:27:53 -05:00

104 lines
3.0 KiB
TypeScript

/**
* Copyright (c) OpenLens Authors. All rights reserved.
* Licensed under MIT License. See LICENSE in root directory for more information.
*/
import "./kube-event-details.scss";
import React from "react";
import { disposeOnUnmount, observer } from "mobx-react";
import { KubeObject } from "../../../common/k8s-api/kube-object";
import { DrawerItem, DrawerTitle } from "../drawer";
import { cssNames } from "../../utils";
import { LocaleDate } from "../locale-date";
import type { EventStore } from "./store";
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 eventStoreInjectable from "./store.injectable";
import loggerInjectable from "../../../common/logger.injectable";
export interface KubeEventDetailsProps {
object: KubeObject;
}
interface Dependencies {
subscribeStores: SubscribeStores;
eventStore: EventStore;
logger: Logger;
}
@observer
class NonInjectedKubeEventDetails extends React.Component<KubeEventDetailsProps & Dependencies> {
componentDidMount() {
disposeOnUnmount(this, [
this.props.subscribeStores([
this.props.eventStore,
]),
]);
}
render() {
const { object, eventStore } = this.props;
if (!object) {
return null;
}
if (!(object instanceof KubeObject)) {
this.props.logger.error("[KubeEventDetails]: passed object that is not an instanceof KubeObject", object);
return null;
}
const events = eventStore.getEventsByObject(object);
return (
<div>
<DrawerTitle className="flex gaps align-center">
<span>Events</span>
</DrawerTitle>
{events.length > 0 && (
<div className="KubeEventDetails">
{events.map(event => (
<div className="event" key={event.getId()}>
<div className={cssNames("title", { warning: event.isWarning() })}>
{event.message}
</div>
<DrawerItem name="Source">
{event.getSource()}
</DrawerItem>
<DrawerItem name="Count">
{event.count}
</DrawerItem>
<DrawerItem name="Sub-object">
{event.involvedObject.fieldPath}
</DrawerItem>
{event.lastTimestamp && (
<DrawerItem name="Last seen">
<LocaleDate date={event.lastTimestamp} />
</DrawerItem>
)}
</div>
))}
</div>
)}
</div>
);
}
}
export const KubeEventDetails = withInjectables<Dependencies, KubeEventDetailsProps>(NonInjectedKubeEventDetails, {
getProps: (di, props) => ({
...props,
subscribeStores: di.inject(subscribeStoresInjectable),
eventStore: di.inject(eventStoreInjectable),
logger: di.inject(loggerInjectable),
}),
});