import "./install-chart.scss"; import React, { Component } from "react"; import { observable, makeObservable } from "mobx"; import { observer } from "mobx-react"; import { dockStore, IDockTab } from "./dock.store"; import { InfoPanel } from "./info-panel"; import { Badge } from "../badge"; import { NamespaceSelect } from "../+namespaces/namespace-select"; import { autobind, prevDefault } from "../../utils"; import { IChartInstallData, installChartStore } from "./install-chart.store"; import { Spinner } from "../spinner"; import { Icon } from "../icon"; import { Button } from "../button"; import { releaseURL } from "../+apps-releases"; import { releaseStore } from "../+apps-releases/release.store"; import { LogsDialog } from "../dialog/logs-dialog"; import { Select, SelectOption } from "../select"; import { Input } from "../input"; import { EditorPanel } from "./editor-panel"; import { navigate } from "../../navigation"; interface Props { tab: IDockTab; } @observer export class InstallChart extends Component { @observable error = ""; @observable showNotes = false; constructor(props: Props) { super(props); makeObservable(this); } get values() { return this.chartData.values; } get chartData() { return installChartStore.getData(this.tabId); } get tabId() { return this.props.tab.id; } get versions() { return installChartStore.versions.getData(this.tabId); } get releaseDetails() { return installChartStore.details.getData(this.tabId); } @autobind viewRelease() { const { release } = this.releaseDetails; navigate(releaseURL({ params: { name: release.name, namespace: release.namespace } })); dockStore.closeTab(this.tabId); } @autobind save(data: Partial) { const chart = { ...this.chartData, ...data }; installChartStore.setData(this.tabId, chart); } @autobind onVersionChange(option: SelectOption) { const version = option.value; this.save({ version, values: "" }); installChartStore.loadValues(this.tabId); } @autobind onValuesChange(values: string, error?: string) { this.error = error; this.save({ values }); } @autobind onNamespaceChange(opt: SelectOption) { this.save({ namespace: opt.value }); } @autobind onReleaseNameChange(name: string) { this.save({ releaseName: name }); } install = async () => { const { repo, name, version, namespace, values, releaseName } = this.chartData; const details = await releaseStore.create({ name: releaseName || undefined, chart: name, repo, namespace, version, values, }); installChartStore.details.setData(this.tabId, details); return (

Chart Release {details.release.name} successfully created.

); }; render() { const { tabId, chartData, values, versions, install } = this; if (chartData?.values === undefined || !versions) { return ; } if (this.releaseDetails) { return (

Installation complete!

this.showNotes = false} logs={this.releaseDetails.log} />
); } const { repo, name, version, namespace, releaseName } = chartData; const panelControls = (
Chart Version
); return (
); } }