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 { autorun, observable } from "mobx"; import { disposeOnUnmount, 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 description: string = null; private chartPromise: CancelablePromise<{ readme: string; versions: HelmChart[] }>; @disposeOnUnmount chartSelector = autorun(async () => { if (!this.props.chart) return; this.chartVersions = null; this.selectedChart = null; this.description = null; this.loadChartData(); this.chartPromise.then(data => { this.description = data.readme; this.chartVersions = data.versions; this.selectedChart = data.versions[0]; }); }); loadChartData(version?: string) { const { chart: { name, repo } } = this.props; if (this.chartPromise) this.chartPromise.cancel(); this.chartPromise = helmChartsApi.get(repo, name, version); } @autobind() onVersionChange(opt: SelectOption) { const version = opt.value; this.selectedChart = this.chartVersions.find(chart => chart.version === version); this.description = null; this.loadChartData(version); this.chartPromise.then(data => { this.description = data.readme }); } @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()}