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, toJS } 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[] }>; async componentDidMount() { const { chart: { name, repo, version } } = this.props try { const { readme, versions } = await (this.chartPromise = helmChartsApi.get(repo, name, version)) this.readme = readme this.chartVersions = versions this.selectedChart = versions[0] } catch (error) { this.error = error } } componentWillUnmount() { this.chartPromise?.cancel(); } @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()}