/** * Copyright (c) OpenLens Authors. All rights reserved. * Licensed under MIT License. See LICENSE in root directory for more information. */ import "./upgrade-chart.scss"; import React from "react"; import { action, makeObservable, observable, reaction } from "mobx"; import { disposeOnUnmount, observer } from "mobx-react"; import { cssNames } from "../../../utils"; import type { DockTab } from "../dock/store"; import { InfoPanel } from "../info-panel"; import type { UpgradeChartTabStore } from "./store"; import { Spinner } from "../../spinner"; import { Badge } from "../../badge"; import { EditorPanel } from "../editor-panel"; import { helmChartStore, type IChartVersion } from "../../+helm-charts/helm-chart.store"; import type { HelmRelease, IReleaseUpdateDetails, IReleaseUpdatePayload } from "../../../../common/k8s-api/endpoints/helm-releases.api"; import type { SelectOption } from "../../select"; import { Select } from "../../select"; import type { IAsyncComputed } from "@ogre-tools/injectable-react"; import { withInjectables } from "@ogre-tools/injectable-react"; import upgradeChartTabStoreInjectable from "./store.injectable"; import updateReleaseInjectable from "../../+helm-releases/update-release/update-release.injectable"; import releasesInjectable from "../../+helm-releases/releases.injectable"; export interface UpgradeChartProps { className?: string; tab: DockTab; } interface Dependencies { releases: IAsyncComputed; upgradeChartTabStore: UpgradeChartTabStore; updateRelease: (name: string, namespace: string, payload: IReleaseUpdatePayload) => Promise; } @observer export class NonInjectedUpgradeChart extends React.Component { @observable error: string; @observable versions = observable.array(); @observable version: IChartVersion; constructor(props: UpgradeChartProps & Dependencies) { super(props); makeObservable(this); } componentDidMount() { disposeOnUnmount(this, [ reaction( () => this.release, release => this.reloadVersions(release), { fireImmediately: true, }, ), reaction( () => this.release?.getRevision(), () => this.reloadValues(), { fireImmediately: true, }, ), ]); } get tabId() { return this.props.tab.id; } get release(): HelmRelease { const tabData = this.props.upgradeChartTabStore.getData(this.tabId); if (!tabData) return null; return this.props.releases.value.get().find(release => release.getName() === tabData.releaseName); } get value() { return this.props.upgradeChartTabStore.values.getData(this.tabId); } async reloadValues() { this.props.upgradeChartTabStore.reloadValues(this.props.tab.id); } async reloadVersions(release: HelmRelease) { if (!release) { return; } this.version = null; this.versions.clear(); const versions = await helmChartStore.getVersions(this.release.getChart()); this.versions.replace(versions); this.version = this.versions[0]; } onChange = action((value: string) => { this.error = ""; this.props.upgradeChartTabStore.values.setData(this.tabId, value); }); onError = action((error: Error | string) => { this.error = error.toString(); }); upgrade = async () => { if (this.error) return null; const { version, repo } = this.version; const releaseName = this.release.getName(); const releaseNs = this.release.getNs(); await this.props.updateRelease(releaseName, releaseNs, { chart: this.release.getChart(), values: this.value, repo, version, }); return (

Release {releaseName} successfully upgraded to version {version}

); }; formatVersionLabel = ({ value }: SelectOption) => { const chartName = this.release.getChart(); const { repo, version } = value; return `${repo}/${chartName}-${version}`; }; render() { const { tabId, release, value, error, onChange, onError, upgrade, versions, version } = this; const { className } = this.props; if (!release || !this.props.upgradeChartTabStore.isReady(tabId) || !version) { return ; } const currentVersion = release.getVersion(); const controlsAndInfo = (
Release Namespace Version Upgrade version