mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
62 lines
1.9 KiB
TypeScript
62 lines
1.9 KiB
TypeScript
import "./cluster-icon.scss"
|
|
|
|
import React, { DOMAttributes } from "react";
|
|
import { observer } from "mobx-react";
|
|
import { Params as HashiconParams } from "@emeraldpay/hashicon";
|
|
import { Hashicon } from "@emeraldpay/hashicon-react";
|
|
import { Cluster } from "../../../main/cluster";
|
|
import { cssNames, IClassName } from "../../utils";
|
|
import { Badge } from "../badge";
|
|
import { Tooltip } from "../tooltip";
|
|
|
|
interface Props extends DOMAttributes<HTMLElement> {
|
|
cluster: Cluster;
|
|
className?: IClassName;
|
|
errorClass?: IClassName;
|
|
showErrors?: boolean;
|
|
showTooltip?: boolean;
|
|
interactive?: boolean;
|
|
isActive?: boolean;
|
|
options?: HashiconParams;
|
|
}
|
|
|
|
const defaultProps: Partial<Props> = {
|
|
showErrors: true,
|
|
showTooltip: true,
|
|
};
|
|
|
|
@observer
|
|
export class ClusterIcon extends React.Component<Props> {
|
|
static defaultProps = defaultProps as object;
|
|
|
|
render() {
|
|
const {
|
|
cluster, showErrors, showTooltip, errorClass, options, interactive, isActive,
|
|
children, ...elemProps
|
|
} = this.props;
|
|
const { isAdmin, eventCount, preferences, id: clusterId } = cluster;
|
|
const { clusterName, icon } = preferences;
|
|
const clusterIconId = `cluster-icon-${clusterId}`;
|
|
const className = cssNames("ClusterIcon flex inline", this.props.className, {
|
|
interactive: interactive !== undefined ? interactive : !!this.props.onClick,
|
|
active: isActive,
|
|
});
|
|
return (
|
|
<div {...elemProps} className={className} id={clusterIconId}>
|
|
{showTooltip && (
|
|
<Tooltip targetId={clusterIconId}>{clusterName}</Tooltip>
|
|
)}
|
|
{icon && <img src={icon} alt={clusterName}/>}
|
|
{!icon && <Hashicon value={clusterName} options={options}/>}
|
|
{showErrors && isAdmin && eventCount > 0 && (
|
|
<Badge
|
|
className={cssNames("events-count", errorClass)}
|
|
label={eventCount >= 1000 ? Math.ceil(eventCount / 1000) + "k+" : eventCount}
|
|
/>
|
|
)}
|
|
{children}
|
|
</div>
|
|
);
|
|
}
|
|
}
|