import "./helm-chart-details.scss"; import React, { Component } from "react"; import { HelmChart, helmChartsApi } from "../../api/endpoints/helm-charts.api"; import { t, Trans } from "@lingui/macro"; import { observable, autorun } from "mobx"; import { observer } from "mobx-react"; import { Drawer, DrawerItem } from "../drawer"; import { autobind, stopPropagation } from "../../utils"; import { MarkdownViewer } from "../markdown-viewer"; import { Spinner } from "../spinner"; import { CancelablePromise } from "../../utils/cancelableFetch"; import { Button } from "../button"; import { Select, SelectOption } from "../select"; import { createInstallChartTab } from "../dock/install-chart.store"; import { Badge } from "../badge"; import { _i18n } from "../../i18n"; interface Props { chart: HelmChart; hideDetails(): void; } @observer export class HelmChartDetails extends Component { @observable chartVersions: HelmChart[]; @observable selectedChart: HelmChart; @observable readme: string = null; @observable error: string = null; private chartPromise: CancelablePromise<{ readme: string; versions: HelmChart[] }>; componentWillUnmount() { this.chartPromise?.cancel(); } chartUpdater = autorun(() => { this.selectedChart = null; const { chart: { name, repo, version } } = this.props; helmChartsApi.get(repo, name, version).then(result => { this.readme = result.readme; this.chartVersions = result.versions; this.selectedChart = result.versions[0]; }, error => { this.error = error; }); }); @autobind() async onVersionChange({ value: version }: SelectOption) { this.selectedChart = this.chartVersions.find(chart => chart.version === version); this.readme = null; try { this.chartPromise?.cancel(); const { chart: { name, repo } } = this.props; const { readme } = await (this.chartPromise = helmChartsApi.get(repo, name, version)); this.readme = readme; } catch (error) { this.error = error; } } @autobind() install() { createInstallChartTab(this.selectedChart); this.props.hideDetails(); } renderIntroduction() { const { selectedChart, chartVersions, onVersionChange } = this; const placeholder = require("./helm-placeholder.svg"); return (
event.currentTarget.src = placeholder} />
{selectedChart.getDescription()}