| Yoshie Muranaka | 7bc85e4 | 2021-02-11 09:59:13 -0800 | [diff] [blame] | 1 | <template> |
| 2 | <div> |
| 3 | <page-section :section-title="sectionTitle"> |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 4 | <b-row class="row-cols-1 row-cols-md-2"> |
| Yoshie Muranaka | 7bc85e4 | 2021-02-11 09:59:13 -0800 | [diff] [blame] | 5 | <!-- Running image --> |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 6 | <b-col class="mb-3"> |
| 7 | <b-card class="h-100"> |
| 8 | <template #header> |
| 9 | <p class="fw-bold m-0"> |
| 10 | {{ $t('pageFirmware.cardTitleRunning') }} |
| 11 | </p> |
| 12 | </template> |
| 13 | <dl class="mb-0"> |
| 14 | <dt>{{ $t('pageFirmware.cardBodyVersion') }}</dt> |
| 15 | <dd class="mb-0">{{ runningVersion }}</dd> |
| 16 | </dl> |
| 17 | </b-card> |
| 18 | </b-col> |
| Yoshie Muranaka | 7bc85e4 | 2021-02-11 09:59:13 -0800 | [diff] [blame] | 19 | |
| 20 | <!-- Backup image --> |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 21 | <b-col class="mb-3"> |
| 22 | <b-card class="h-100"> |
| 23 | <template #header> |
| 24 | <p class="fw-bold m-0"> |
| 25 | {{ $t('pageFirmware.cardTitleBackup') }} |
| 26 | </p> |
| 27 | </template> |
| 28 | <dl> |
| 29 | <dt>{{ $t('pageFirmware.cardBodyVersion') }}</dt> |
| 30 | <dd> |
| 31 | <status-icon v-if="showBackupImageStatus" status="danger" /> |
| 32 | <span |
| 33 | v-if="showBackupImageStatus" |
| 34 | class="visually-hidden-focusable" |
| 35 | > |
| 36 | {{ backupStatus }} |
| 37 | </span> |
| 38 | {{ backupVersion }} |
| 39 | </dd> |
| 40 | </dl> |
| 41 | <b-btn |
| 42 | v-if="!switchToBackupImageDisabled" |
| 43 | data-test-id="firmware-button-switchToRunning" |
| 44 | variant="link" |
| 45 | size="sm" |
| 46 | class="py-0 px-1 mt-2" |
| 47 | :disabled="isPageDisabled || !backup || !isServerOff" |
| 48 | @click="showSwitchToRunning = true" |
| 49 | > |
| 50 | <icon-switch class="d-none d-sm-inline-block" /> |
| 51 | {{ $t('pageFirmware.cardActionSwitchToRunning') }} |
| 52 | </b-btn> |
| 53 | </b-card> |
| 54 | </b-col> |
| 55 | </b-row> |
| Yoshie Muranaka | 7bc85e4 | 2021-02-11 09:59:13 -0800 | [diff] [blame] | 56 | </page-section> |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 57 | <modal-switch-to-running |
| 58 | v-model="showSwitchToRunning" |
| 59 | :backup="backupVersion" |
| 60 | @ok="switchToRunning" |
| 61 | /> |
| Yoshie Muranaka | 7bc85e4 | 2021-02-11 09:59:13 -0800 | [diff] [blame] | 62 | </div> |
| 63 | </template> |
| 64 | |
| 65 | <script> |
| 66 | import IconSwitch from '@carbon/icons-vue/es/arrows--horizontal/20'; |
| 67 | import PageSection from '@/components/Global/PageSection'; |
| 68 | import LoadingBarMixin, { loading } from '@/components/Mixins/LoadingBarMixin'; |
| 69 | import BVToastMixin from '@/components/Mixins/BVToastMixin'; |
| 70 | |
| 71 | import ModalSwitchToRunning from './FirmwareModalSwitchToRunning'; |
| Surya V | de23ea2 | 2024-07-11 15:19:46 +0530 | [diff] [blame] | 72 | import { useI18n } from 'vue-i18n'; |
| 73 | import i18n from '@/i18n'; |
| Yoshie Muranaka | 7bc85e4 | 2021-02-11 09:59:13 -0800 | [diff] [blame] | 74 | |
| 75 | export default { |
| 76 | components: { IconSwitch, ModalSwitchToRunning, PageSection }, |
| 77 | mixins: [BVToastMixin, LoadingBarMixin], |
| 78 | props: { |
| 79 | isPageDisabled: { |
| 80 | required: true, |
| 81 | type: Boolean, |
| 82 | default: false, |
| 83 | }, |
| Kenneth Fullbright | c3cf361 | 2022-01-27 18:55:00 -0600 | [diff] [blame] | 84 | isServerOff: { |
| 85 | required: true, |
| 86 | type: Boolean, |
| 87 | default: false, |
| 88 | }, |
| Yoshie Muranaka | 7bc85e4 | 2021-02-11 09:59:13 -0800 | [diff] [blame] | 89 | }, |
| 90 | data() { |
| 91 | return { |
| Surya V | de23ea2 | 2024-07-11 15:19:46 +0530 | [diff] [blame] | 92 | $t: useI18n().t, |
| Yoshie Muranaka | 7bc85e4 | 2021-02-11 09:59:13 -0800 | [diff] [blame] | 93 | loading, |
| MichalX Szopinski | f65cc7b | 2021-07-12 10:56:16 +0200 | [diff] [blame] | 94 | switchToBackupImageDisabled: |
| 95 | process.env.VUE_APP_SWITCH_TO_BACKUP_IMAGE_DISABLED === 'true', |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 96 | showSwitchToRunning: false, |
| Yoshie Muranaka | 7bc85e4 | 2021-02-11 09:59:13 -0800 | [diff] [blame] | 97 | }; |
| 98 | }, |
| 99 | computed: { |
| 100 | isSingleFileUploadEnabled() { |
| Yoshie Muranaka | 33d755f | 2021-02-18 15:24:14 -0800 | [diff] [blame] | 101 | return this.$store.getters['firmware/isSingleFileUploadEnabled']; |
| Yoshie Muranaka | 7bc85e4 | 2021-02-11 09:59:13 -0800 | [diff] [blame] | 102 | }, |
| 103 | sectionTitle() { |
| 104 | if (this.isSingleFileUploadEnabled) { |
| Surya V | de23ea2 | 2024-07-11 15:19:46 +0530 | [diff] [blame] | 105 | return i18n.global.t('pageFirmware.sectionTitleBmcCardsCombined'); |
| Yoshie Muranaka | 7bc85e4 | 2021-02-11 09:59:13 -0800 | [diff] [blame] | 106 | } |
| Surya V | de23ea2 | 2024-07-11 15:19:46 +0530 | [diff] [blame] | 107 | return i18n.global.t('pageFirmware.sectionTitleBmcCards'); |
| Yoshie Muranaka | 7bc85e4 | 2021-02-11 09:59:13 -0800 | [diff] [blame] | 108 | }, |
| 109 | running() { |
| Yoshie Muranaka | 33d755f | 2021-02-18 15:24:14 -0800 | [diff] [blame] | 110 | return this.$store.getters['firmware/activeBmcFirmware']; |
| Yoshie Muranaka | 7bc85e4 | 2021-02-11 09:59:13 -0800 | [diff] [blame] | 111 | }, |
| 112 | backup() { |
| Yoshie Muranaka | 33d755f | 2021-02-18 15:24:14 -0800 | [diff] [blame] | 113 | return this.$store.getters['firmware/backupBmcFirmware']; |
| Yoshie Muranaka | 7bc85e4 | 2021-02-11 09:59:13 -0800 | [diff] [blame] | 114 | }, |
| 115 | runningVersion() { |
| 116 | return this.running?.version || '--'; |
| 117 | }, |
| 118 | backupVersion() { |
| 119 | return this.backup?.version || '--'; |
| 120 | }, |
| 121 | backupStatus() { |
| 122 | return this.backup?.status || null; |
| 123 | }, |
| 124 | showBackupImageStatus() { |
| 125 | return ( |
| 126 | this.backupStatus === 'Critical' || this.backupStatus === 'Warning' |
| 127 | ); |
| 128 | }, |
| 129 | }, |
| 130 | methods: { |
| 131 | switchToRunning() { |
| 132 | this.startLoader(); |
| 133 | const timerId = setTimeout(() => { |
| 134 | this.endLoader(); |
| Surya V | de23ea2 | 2024-07-11 15:19:46 +0530 | [diff] [blame] | 135 | this.infoToast( |
| 136 | i18n.global.t('pageFirmware.toast.verifySwitchMessage'), |
| 137 | { |
| 138 | title: i18n.global.t('pageFirmware.toast.verifySwitch'), |
| 139 | refreshAction: true, |
| 140 | }, |
| 141 | ); |
| Yoshie Muranaka | 7bc85e4 | 2021-02-11 09:59:13 -0800 | [diff] [blame] | 142 | }, 60000); |
| 143 | |
| 144 | this.$store |
| Yoshie Muranaka | 33d755f | 2021-02-18 15:24:14 -0800 | [diff] [blame] | 145 | .dispatch('firmware/switchBmcFirmwareAndReboot') |
| Yoshie Muranaka | 7bc85e4 | 2021-02-11 09:59:13 -0800 | [diff] [blame] | 146 | .then(() => |
| Surya V | de23ea2 | 2024-07-11 15:19:46 +0530 | [diff] [blame] | 147 | this.infoToast( |
| 148 | i18n.global.t('pageFirmware.toast.rebootStartedMessage'), |
| 149 | { |
| 150 | title: i18n.global.t('pageFirmware.toast.rebootStarted'), |
| 151 | }, |
| 152 | ), |
| Yoshie Muranaka | 7bc85e4 | 2021-02-11 09:59:13 -0800 | [diff] [blame] | 153 | ) |
| 154 | .catch(({ message }) => { |
| 155 | this.errorToast(message); |
| 156 | clearTimeout(timerId); |
| 157 | this.endLoader(); |
| 158 | }); |
| 159 | }, |
| 160 | }, |
| 161 | }; |
| 162 | </script> |