import "./release-details.scss"; import React, { Component } from "react"; import groupBy from "lodash/groupBy"; import isEqual from "lodash/isEqual"; import { observable, reaction } from "mobx"; import { Link } from "react-router-dom"; import kebabCase from "lodash/kebabCase"; import { getRelease, getReleaseValues, HelmRelease, IReleaseDetails } from "../../api/endpoints/helm-releases.api"; import { HelmReleaseMenu } from "./release-menu"; import { Drawer, DrawerItem, DrawerTitle } from "../drawer"; import { Badge } from "../badge"; import { cssNames, stopPropagation } from "../../utils"; import { disposeOnUnmount, observer } from "mobx-react"; import { Spinner } from "../spinner"; import { Table, TableCell, TableHead, TableRow } from "../table"; import { AceEditor } from "../ace-editor"; import { Button } from "../button"; import { releaseStore } from "./release.store"; import { Notifications } from "../notifications"; import { createUpgradeChartTab } from "../dock/upgrade-chart.store"; import { themeStore } from "../../theme.store"; import { apiManager } from "../../api/api-manager"; import { SubTitle } from "../layout/sub-title"; import { secretsStore } from "../+config-secrets/secrets.store"; import { Secret } from "../../api/endpoints"; import { getDetailsUrl } from "../kube-object"; import { Checkbox } from "../checkbox"; interface Props { release: HelmRelease; hideDetails(): void; } @observer export class ReleaseDetails extends Component { @observable details: IReleaseDetails; @observable values = ""; @observable valuesLoading = false; @observable userSuppliedOnly = false; @observable saving = false; @observable releaseSecret: Secret; @disposeOnUnmount releaseSelector = reaction(() => this.props.release, release => { if (!release) return; this.loadDetails(); this.loadValues(); this.releaseSecret = null; } ); @disposeOnUnmount secretWatcher = reaction(() => secretsStore.items.toJS(), () => { if (!this.props.release) return; const { getReleaseSecret } = releaseStore; const { release } = this.props; const secret = getReleaseSecret(release); if (this.releaseSecret) { if (isEqual(this.releaseSecret.getLabels(), secret.getLabels())) return; this.loadDetails(); } this.releaseSecret = secret; }); async loadDetails() { const { release } = this.props; this.details = null; this.details = await getRelease(release.getName(), release.getNs()); } async loadValues() { const { release } = this.props; this.values = ""; this.valuesLoading = true; this.values = (await getReleaseValues(release.getName(), release.getNs(), !this.userSuppliedOnly)) ?? ""; this.valuesLoading = false; } updateValues = async () => { const { release } = this.props; const name = release.getName(); const namespace = release.getNs(); const data = { chart: release.getChart(), repo: await release.getRepo(), version: release.getVersion(), values: this.values }; this.saving = true; try { await releaseStore.update(name, namespace, data); Notifications.ok(

Release {name} successfully updated!

); } catch (err) { Notifications.error(err); } this.saving = false; }; upgradeVersion = () => { const { release, hideDetails } = this.props; createUpgradeChartTab(release); hideDetails(); }; renderValues() { const { values, valuesLoading, saving } = this; return (
{ this.userSuppliedOnly = values; this.loadValues(); }} disabled={valuesLoading} /> {valuesLoading ? : this.values = values} /> }
); } renderNotes() { if (!this.details.info?.notes) return null; const { notes } = this.details.info; return (
{notes}
); } renderResources() { const { resources } = this.details; if (!resources) return null; const groups = groupBy(resources, item => item.kind); const tables = Object.entries(groups).map(([kind, items]) => { return ( Name {items[0].getNs() && Namespace} Age {items.map(item => { const name = item.getName(); const namespace = item.getNs(); const api = apiManager.getApi(item.metadata.selfLink); const detailsUrl = api ? getDetailsUrl(api.getUrl({ name, namespace })) : ""; return ( {detailsUrl ? {name} : name} {namespace && {namespace}} {item.getAge()} ); })}
); }); return (
{tables}
); } renderContent() { const { release } = this.props; const { details } = this; if (!release) return null; if (!details) { return ; } return (
{release.getChart()}
{release.getUpdated()} ago ({release.updated}) {release.getNs()}
{release.getVersion()}
{this.renderValues()} {this.renderNotes()} {this.renderResources()}
); } render() { const { release, hideDetails } = this.props; const title = release ? <>Release: {release.getName()} : ""; const toolbar = ; return ( {this.renderContent()} ); } }