import * as React from "react"; import { t, Trans } from "@lingui/macro"; import { HelmRelease } from "../../api/endpoints/helm-releases.api"; import { autobind, cssNames } from "../../utils"; import { releaseStore } from "./release.store"; import { MenuActions, MenuActionsProps } from "../menu/menu-actions"; import { MenuItem } from "../menu"; import { Icon } from "../icon"; import { ReleaseRollbackDialog } from "./release-rollback-dialog"; import { createUpgradeChartTab } from "../dock/upgrade-chart.store"; import { _i18n } from "../../i18n"; interface Props extends MenuActionsProps { release: HelmRelease; hideDetails?(): void; } export class HelmReleaseMenu extends React.Component { @autobind() remove(): Promise { return releaseStore.remove(this.props.release); } @autobind() upgrade(): void { const { release, hideDetails } = this.props; createUpgradeChartTab(release); hideDetails && hideDetails(); } @autobind() rollback(): void { ReleaseRollbackDialog.open(this.props.release); } renderContent(): JSX.Element { const { release, toolbar } = this.props; if (!release) { return; } const hasRollback = release && release.revision > 1; return ( <> {hasRollback && ( Rollback )} ); } render(): JSX.Element { const { className, release: _release, ...menuProps } = this.props; return ( {this.renderContent()} ); } }