| Dixsie Wolmers | 97d86b3 | 2019-12-02 05:07:57 -0600 | [diff] [blame] | 1 | <template> |
| Yoshie Muranaka | 3111b6f | 2020-04-21 19:48:38 -0700 | [diff] [blame] | 2 | <b-container fluid="xl"> |
| Derick Montague | 09e45cd | 2020-01-23 15:45:57 -0600 | [diff] [blame] | 3 | <page-title /> |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 4 | <overview-quick-links class="mb-4" /> |
| 5 | <page-section |
| 6 | :section-title="$t('pageOverview.systemInformation')" |
| 7 | class="mb-1" |
| 8 | > |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 9 | <b-row class="row-cols-1 row-cols-md-2"> |
| 10 | <b-col class="mb-3"> |
| 11 | <overview-server class="h-100" /> |
| 12 | </b-col> |
| 13 | <b-col class="mb-3"> |
| 14 | <overview-firmware class="h-100" /> |
| 15 | </b-col> |
| 16 | </b-row> |
| 17 | <b-row class="row-cols-1 row-cols-md-2"> |
| 18 | <b-col class="mb-3"> |
| 19 | <overview-network class="h-100" /> |
| 20 | </b-col> |
| 21 | <b-col class="mb-3"> |
| 22 | <overview-power class="h-100" /> |
| 23 | </b-col> |
| 24 | </b-row> |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 25 | </page-section> |
| 26 | <page-section :section-title="$t('pageOverview.statusInformation')"> |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 27 | <b-row class="row-cols-1 row-cols-md-2"> |
| 28 | <b-col class="mb-3"> |
| 29 | <overview-events class="h-100" /> |
| 30 | </b-col> |
| 31 | <b-col class="mb-3"> |
| 32 | <overview-inventory class="h-100" /> |
| 33 | </b-col> |
| 34 | <b-col v-if="showDumps" class="mb-3"> |
| 35 | <overview-dumps class="h-100" /> |
| 36 | </b-col> |
| 37 | </b-row> |
| Derick Montague | 09e45cd | 2020-01-23 15:45:57 -0600 | [diff] [blame] | 38 | </page-section> |
| Dixsie Wolmers | 97d86b3 | 2019-12-02 05:07:57 -0600 | [diff] [blame] | 39 | </b-container> |
| 40 | </template> |
| 41 | |
| 42 | <script> |
| Yoshie Muranaka | 598bf7e | 2020-05-01 12:26:00 -0700 | [diff] [blame] | 43 | import LoadingBarMixin from '@/components/Mixins/LoadingBarMixin'; |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 44 | import OverviewDumps from './OverviewDumps.vue'; |
| 45 | import OverviewEvents from './OverviewEvents.vue'; |
| 46 | import OverviewFirmware from './OverviewFirmware.vue'; |
| 47 | import OverviewInventory from './OverviewInventory.vue'; |
| 48 | import OverviewNetwork from './OverviewNetwork'; |
| 49 | import OverviewPower from './OverviewPower'; |
| 50 | import OverviewQuickLinks from './OverviewQuickLinks'; |
| 51 | import OverviewServer from './OverviewServer'; |
| 52 | import PageSection from '@/components/Global/PageSection'; |
| 53 | import PageTitle from '@/components/Global/PageTitle'; |
| Ed Tanous | 883a0d5 | 2024-03-23 14:56:34 -0700 | [diff] [blame] | 54 | import { useI18n } from 'vue-i18n'; |
| Dixsie Wolmers | 9d40e30 | 2020-02-13 13:29:40 -0600 | [diff] [blame] | 55 | |
| Dixsie Wolmers | 97d86b3 | 2019-12-02 05:07:57 -0600 | [diff] [blame] | 56 | export default { |
| Derick Montague | e2fd156 | 2019-12-20 13:26:53 -0600 | [diff] [blame] | 57 | name: 'Overview', |
| Dixsie Wolmers | 97d86b3 | 2019-12-02 05:07:57 -0600 | [diff] [blame] | 58 | components: { |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 59 | OverviewDumps, |
| Dixsie Wolmers | f65ee34 | 2020-01-22 19:47:56 -0600 | [diff] [blame] | 60 | OverviewEvents, |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 61 | OverviewFirmware, |
| 62 | OverviewInventory, |
| Dixsie Wolmers | 9d40e30 | 2020-02-13 13:29:40 -0600 | [diff] [blame] | 63 | OverviewNetwork, |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 64 | OverviewPower, |
| 65 | OverviewQuickLinks, |
| 66 | OverviewServer, |
| Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame] | 67 | PageSection, |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 68 | PageTitle, |
| Dixsie Wolmers | 97d86b3 | 2019-12-02 05:07:57 -0600 | [diff] [blame] | 69 | }, |
| Yoshie Muranaka | 598bf7e | 2020-05-01 12:26:00 -0700 | [diff] [blame] | 70 | mixins: [LoadingBarMixin], |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 71 | data() { |
| 72 | return { |
| Ed Tanous | 883a0d5 | 2024-03-23 14:56:34 -0700 | [diff] [blame] | 73 | $t: useI18n().t, |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 74 | showDumps: process.env.VUE_APP_ENV_NAME === 'ibm', |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 75 | // Promise resolvers |
| 76 | dumpsResolver: null, |
| 77 | eventsResolver: null, |
| 78 | selResolver: null, |
| 79 | firmwareResolver: null, |
| 80 | inventoryResolver: null, |
| 81 | networkResolver: null, |
| 82 | powerResolver: null, |
| 83 | quicklinksResolver: null, |
| 84 | serverResolver: null, |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 85 | }; |
| Yoshie Muranaka | 98bb24e | 2020-10-06 10:00:19 -0700 | [diff] [blame] | 86 | }, |
| Derick Montague | 09e45cd | 2020-01-23 15:45:57 -0600 | [diff] [blame] | 87 | created() { |
| Yoshie Muranaka | 598bf7e | 2020-05-01 12:26:00 -0700 | [diff] [blame] | 88 | this.startLoader(); |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 89 | |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 90 | const dumpsPromise = new Promise((resolve) => { |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 91 | this.dumpsResolver = resolve; |
| 92 | this.$eventBus.on('overview-dumps-complete', () => resolve()); |
| Yoshie Muranaka | 598bf7e | 2020-05-01 12:26:00 -0700 | [diff] [blame] | 93 | }); |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 94 | |
| Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame] | 95 | const eventsPromise = new Promise((resolve) => { |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 96 | this.eventsResolver = resolve; |
| 97 | this.$eventBus.on('overview-events-complete', () => resolve()); |
| Yoshie Muranaka | 598bf7e | 2020-05-01 12:26:00 -0700 | [diff] [blame] | 98 | }); |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 99 | |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 100 | const firmwarePromise = new Promise((resolve) => { |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 101 | this.firmwareResolver = resolve; |
| 102 | this.$eventBus.on('overview-firmware-complete', () => resolve()); |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 103 | }); |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 104 | |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 105 | const inventoryPromise = new Promise((resolve) => { |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 106 | this.inventoryResolver = resolve; |
| 107 | this.$eventBus.on('overview-inventory-complete', () => resolve()); |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 108 | }); |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 109 | |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 110 | const networkPromise = new Promise((resolve) => { |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 111 | this.networkResolver = resolve; |
| 112 | this.$eventBus.on('overview-network-complete', () => resolve()); |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 113 | }); |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 114 | |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 115 | const powerPromise = new Promise((resolve) => { |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 116 | this.powerResolver = resolve; |
| 117 | this.$eventBus.on('overview-power-complete', () => resolve()); |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 118 | }); |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 119 | |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 120 | const quicklinksPromise = new Promise((resolve) => { |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 121 | this.quicklinksResolver = resolve; |
| 122 | this.$eventBus.on('overview-quicklinks-complete', () => resolve()); |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 123 | }); |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 124 | |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 125 | const serverPromise = new Promise((resolve) => { |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 126 | this.serverResolver = resolve; |
| 127 | this.$eventBus.on('overview-server-complete', () => resolve()); |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 128 | }); |
| 129 | |
| Konstantin | da53c06 | 2023-02-06 17:25:19 +0300 | [diff] [blame] | 130 | const promises = [ |
| Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame] | 131 | eventsPromise, |
| Dixsie Wolmers | 6a192d5 | 2021-09-02 15:26:58 -0500 | [diff] [blame] | 132 | firmwarePromise, |
| 133 | inventoryPromise, |
| 134 | networkPromise, |
| 135 | powerPromise, |
| 136 | quicklinksPromise, |
| 137 | serverPromise, |
| Konstantin | da53c06 | 2023-02-06 17:25:19 +0300 | [diff] [blame] | 138 | ]; |
| 139 | if (this.showDumps) promises.push(dumpsPromise); |
| jason westover | d36ac8a | 2025-11-03 20:58:59 -0600 | [diff] [blame^] | 140 | Promise.all(promises).finally(() => { |
| 141 | this.endLoader(); |
| 142 | }); |
| 143 | }, |
| 144 | beforeUnmount() { |
| 145 | // Clean up event listeners |
| 146 | this.$eventBus.off('overview-dumps-complete', this.handleDumpsComplete); |
| 147 | this.$eventBus.off('overview-events-complete', this.handleEventsComplete); |
| 148 | this.$eventBus.off('overview-sel-complete', this.handleSelComplete); |
| 149 | this.$eventBus.off( |
| 150 | 'overview-firmware-complete', |
| 151 | this.handleFirmwareComplete, |
| 152 | ); |
| 153 | this.$eventBus.off( |
| 154 | 'overview-inventory-complete', |
| 155 | this.handleInventoryComplete, |
| 156 | ); |
| 157 | this.$eventBus.off('overview-network-complete', this.handleNetworkComplete); |
| 158 | this.$eventBus.off('overview-power-complete', this.handlePowerComplete); |
| 159 | this.$eventBus.off( |
| 160 | 'overview-quicklinks-complete', |
| 161 | this.handleQuicklinksComplete, |
| 162 | ); |
| 163 | this.$eventBus.off('overview-server-complete', this.handleServerComplete); |
| 164 | }, |
| 165 | methods: { |
| 166 | handleDumpsComplete() { |
| 167 | if (this.dumpsResolver) this.dumpsResolver(); |
| 168 | }, |
| 169 | handleEventsComplete() { |
| 170 | if (this.eventsResolver) this.eventsResolver(); |
| 171 | }, |
| 172 | handleSelComplete() { |
| 173 | if (this.selResolver) this.selResolver(); |
| 174 | }, |
| 175 | handleFirmwareComplete() { |
| 176 | if (this.firmwareResolver) this.firmwareResolver(); |
| 177 | }, |
| 178 | handleInventoryComplete() { |
| 179 | if (this.inventoryResolver) this.inventoryResolver(); |
| 180 | }, |
| 181 | handleNetworkComplete() { |
| 182 | if (this.networkResolver) this.networkResolver(); |
| 183 | }, |
| 184 | handlePowerComplete() { |
| 185 | if (this.powerResolver) this.powerResolver(); |
| 186 | }, |
| 187 | handleQuicklinksComplete() { |
| 188 | if (this.quicklinksResolver) this.quicklinksResolver(); |
| 189 | }, |
| 190 | handleServerComplete() { |
| 191 | if (this.serverResolver) this.serverResolver(); |
| 192 | }, |
| Derick Montague | 09e45cd | 2020-01-23 15:45:57 -0600 | [diff] [blame] | 193 | }, |
| Dixsie Wolmers | 97d86b3 | 2019-12-02 05:07:57 -0600 | [diff] [blame] | 194 | }; |
| 195 | </script> |