mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
* remove lingui Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * babelless Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * tweak ts-loader options Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * tweak renderer webpack config Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com>
102 lines
2.8 KiB
TypeScript
102 lines
2.8 KiB
TypeScript
import "./service-details.scss";
|
|
|
|
import React from "react";
|
|
import { observer } from "mobx-react";
|
|
import { DrawerItem, DrawerTitle } from "../drawer";
|
|
import { Badge } from "../badge";
|
|
import { KubeEventDetails } from "../+events/kube-event-details";
|
|
import { KubeObjectDetailsProps } from "../kube-object";
|
|
import { Service, endpointApi } from "../../api/endpoints";
|
|
import { KubeObjectMeta } from "../kube-object/kube-object-meta";
|
|
import { ServicePortComponent } from "./service-port-component";
|
|
import { endpointStore } from "../+network-endpoints/endpoints.store";
|
|
import { ServiceDetailsEndpoint } from "./service-details-endpoint";
|
|
import { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry";
|
|
|
|
interface Props extends KubeObjectDetailsProps<Service> {
|
|
}
|
|
|
|
@observer
|
|
export class ServiceDetails extends React.Component<Props> {
|
|
componentDidMount() {
|
|
if (!endpointStore.isLoaded) {
|
|
endpointStore.loadAll();
|
|
}
|
|
endpointApi.watch();
|
|
}
|
|
|
|
render() {
|
|
const { object: service } = this.props;
|
|
|
|
if (!service) return;
|
|
const { spec } = service;
|
|
const endpoint = endpointStore.getByName(service.getName(), service.getNs());
|
|
|
|
return (
|
|
<div className="ServicesDetails">
|
|
<KubeObjectMeta object={service}/>
|
|
|
|
<DrawerItem name="Selector" labelsOnly>
|
|
{service.getSelector().map(selector => <Badge key={selector} label={selector}/>)}
|
|
</DrawerItem>
|
|
|
|
<DrawerItem name="Type">
|
|
{spec.type}
|
|
</DrawerItem>
|
|
|
|
<DrawerItem name="Session Affinity">
|
|
{spec.sessionAffinity}
|
|
</DrawerItem>
|
|
|
|
<DrawerTitle title={`Connection`}/>
|
|
|
|
<DrawerItem name="Cluster IP">
|
|
{spec.clusterIP}
|
|
</DrawerItem>
|
|
|
|
{service.getExternalIps().length > 0 && (
|
|
<DrawerItem name="External IPs">
|
|
{service.getExternalIps().map(ip => <div key={ip}>{ip}</div>)}
|
|
</DrawerItem>
|
|
)}
|
|
|
|
<DrawerItem name="Ports">
|
|
<div>
|
|
{
|
|
service.getPorts().map((port) => (
|
|
<ServicePortComponent service={service} port={port} key={port.toString()}/>
|
|
))
|
|
}
|
|
</div>
|
|
</DrawerItem>
|
|
|
|
{spec.type === "LoadBalancer" && spec.loadBalancerIP && (
|
|
<DrawerItem name="Load Balancer IP">
|
|
{spec.loadBalancerIP}
|
|
</DrawerItem>
|
|
)}
|
|
<DrawerTitle title={`Endpoint`}/>
|
|
|
|
<ServiceDetailsEndpoint endpoint={endpoint} />
|
|
</div>
|
|
);
|
|
}
|
|
}
|
|
|
|
kubeObjectDetailRegistry.add({
|
|
kind: "Service",
|
|
apiVersions: ["v1"],
|
|
components: {
|
|
Details: (props) => <ServiceDetails {...props} />
|
|
}
|
|
});
|
|
|
|
kubeObjectDetailRegistry.add({
|
|
kind: "Service",
|
|
apiVersions: ["v1"],
|
|
priority: 5,
|
|
components: {
|
|
Details: (props) => <KubeEventDetails {...props} />
|
|
}
|
|
});
|