/** * 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 ChartVersion } from "../../+helm-charts/helm-chart.store"; import type { HelmRelease } 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"; import type { CallForHelmReleaseUpdate } from "../../+helm-releases/update-release/call-for-helm-release-update/call-for-helm-release-update.injectable"; import { first } from "lodash/fp"; export interface UpgradeChartProps { className?: string; tab: DockTab; } interface Dependencies { releases: IAsyncComputed; upgradeChartTabStore: UpgradeChartTabStore; updateRelease: CallForHelmReleaseUpdate; } @observer export class NonInjectedUpgradeChart extends React.Component { @observable error?: string; @observable versions = observable.array(); @observable version: ChartVersion | undefined = undefined; 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() { 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 | null | undefined) { if (!release) { return; } this.version = undefined; this.versions.clear(); const versions = await helmChartStore.getVersions(release.getChart()); this.versions.replace(versions); this.version = first(this.versions); } 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 || !this.release || !this.version || !this.value) { 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}

); }; 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 versionOptions = versions.map(version => ({ value: version, label: `${version.repo}/${release.getChart()}-${version.version}`, })); const controlsAndInfo = (
Release {" "} Namespace {" "} Version {" "} Upgrade version , false> id="char-version-input" className="chart-version" menuPlacement="top" themeName="outlined" value={version} options={versionOptions} onChange={option => this.version = option?.value} />
); return (
); } } export const UpgradeChart = withInjectables(NonInjectedUpgradeChart, { getProps: (di, props) => ({ releases: di.inject(releasesInjectable), updateRelease: di.inject(updateReleaseInjectable), upgradeChartTabStore: di.inject(upgradeChartTabStoreInjectable), ...props, }), });