blob: 852e9fb12c8d113a2a31e574c8125046a039f501 [file] [log] [blame]
<template>
<page-section :section-title="$t('pageFirmware.sectionTitleHostCards')">
<b-card-group deck>
<!-- Running image -->
<b-card>
<template #header>
<p class="font-weight-bold m-0">
{{ $t('pageFirmware.cardTitleRunning') }}
</p>
</template>
<dl class="mb-0">
<dt>{{ $t('pageFirmware.cardBodyVersion') }}</dt>
<dd class="mb-0">{{ runningVersion }}</dd>
</dl>
</b-card>
<!-- Backup image -->
<b-card>
<template #header>
<p class="font-weight-bold m-0">
{{ $t('pageFirmware.cardTitleBackup') }}
</p>
</template>
<dl class="mb-0">
<dt>{{ $t('pageFirmware.cardBodyVersion') }}</dt>
<dd class="mb-0">
<status-icon v-if="showBackupImageStatus" status="danger" />
<span v-if="showBackupImageStatus" class="sr-only">
{{ backupStatus }}
</span>
{{ backupVersion }}
</dd>
</dl>
</b-card>
</b-card-group>
</page-section>
</template>
<script>
import PageSection from '@/components/Global/PageSection';
import { useI18n } from 'vue-i18n';
export default {
components: { PageSection },
data() {
return {
$t: useI18n().t,
};
},
computed: {
running() {
return this.$store.getters['firmware/activeHostFirmware'];
},
backup() {
return this.$store.getters['firmware/backupHostFirmware'];
},
runningVersion() {
return this.running?.version || '--';
},
backupVersion() {
return this.backup?.version || '--';
},
backupStatus() {
return this.backup?.status || null;
},
showBackupImageStatus() {
return (
this.backupStatus === 'Critical' || this.backupStatus === 'Warning'
);
},
},
};
</script>
<style lang="scss" scoped>
@import '@/assets/styles/bmc/helpers/_index.scss';
@import '@/assets/styles/bootstrap/_helpers.scss';
@import '@/assets/styles/bootstrap/_helpers.scss';
.page-section {
margin-top: -$spacer * 1.5;
}
</style>