diff options
author | Dixsie Wolmers <dixsie@ibm.com> | 2021-09-02 23:26:58 +0300 |
---|---|---|
committer | Dixsie Wolmers <dixsiew@gmail.com> | 2021-09-24 16:38:17 +0300 |
commit | 6a192d526c9efebf7a614a9aa473eee62e555fc5 (patch) | |
tree | 536b96e6aab65f05aa2b1ca5d35f3c21fd31186b /src/views/Overview/Overview.vue | |
parent | 348cbfd987a05326f086b713e7f5af93974d74aa (diff) | |
download | webui-vue-6a192d526c9efebf7a614a9aa473eee62e555fc5.tar.xz |
Update overview layout
Layout updates uses bootstrap vue cards to display
general information. View more links and download
or export ability has been added to the overview page.
Network settings displays the hostname and the first IP
address for the first ethernet interface. Link status
was also added.
TODO: Add idle power and power mode properties in seperate
commit for each story.
Signed-off-by: Dixsie Wolmers <dixsie@ibm.com>
Change-Id: Iaf0720d76b2a9416f068a1e779ede59bffda9727
Diffstat (limited to 'src/views/Overview/Overview.vue')
-rw-r--r-- | src/views/Overview/Overview.vue | 201 |
1 files changed, 67 insertions, 134 deletions
diff --git a/src/views/Overview/Overview.vue b/src/views/Overview/Overview.vue index 2436e393..9960f373 100644 --- a/src/views/Overview/Overview.vue +++ b/src/views/Overview/Overview.vue @@ -1,167 +1,100 @@ <template> <b-container fluid="xl"> <page-title /> - <div class="quicklinks-section"> - <overview-quick-links /> - </div> - <b-row> - <b-col> - <page-section :section-title="$t('pageOverview.bmcInformation')"> - <b-row> - <b-col> - <dl> - <dt>{{ $t('pageOverview.firmwareVersion') }}</dt> - <dd>{{ bmcFirmwareVersion }}</dd> - </dl> - </b-col> - </b-row> - </page-section> - <b-row> - <b-col> - <page-section - :section-title="$t('pageOverview.networkInformation')" - > - <overview-network /> - </page-section> - </b-col> - </b-row> - </b-col> - <b-col> - <page-section :section-title="$t('pageOverview.serverInformation')"> - <b-row> - <b-col lg="6"> - <dl> - <dt>{{ $t('pageOverview.model') }}</dt> - <dd>{{ serverModel }}</dd> - </dl> - </b-col> - <b-col lg="6"> - <dl> - <dt>{{ $t('pageOverview.manufacturer') }}</dt> - <dd>{{ serverManufacturer }}</dd> - </dl> - </b-col> - <b-col lg="6"> - <dl> - <dt>{{ $t('pageOverview.serialNumber') }}</dt> - <dd>{{ serverSerialNumber }}</dd> - </dl> - </b-col> - <b-col lg="6"> - <dl> - <dt>{{ $t('pageOverview.firmwareVersion') }}</dt> - <dd>{{ hostFirmwareVersion }}</dd> - </dl> - </b-col> - </b-row> - </page-section> - <page-section :section-title="$t('pageOverview.powerConsumption')"> - <b-row> - <b-col sm="6"> - <dl> - <dt>{{ $t('pageOverview.powerConsumption') }}</dt> - <dd v-if="powerConsumptionValue == null"> - {{ $t('global.status.notAvailable') }} - </dd> - <dd v-else>{{ powerConsumptionValue }} W</dd> - </dl> - </b-col> - <b-col sm="6"> - <dl> - <dt>{{ $t('pageOverview.powerCap') }}</dt> - <dd v-if="powerCapValue == null"> - {{ $t('global.status.disabled') }} - </dd> - <dd v-else>{{ powerCapValue }} W</dd> - </dl> - </b-col> - </b-row> - </page-section> - </b-col> - </b-row> - <page-section :section-title="$t('pageOverview.highPriorityEvents')"> - <overview-events /> + <overview-quick-links class="mb-4" /> + <page-section + :section-title="$t('pageOverview.systemInformation')" + class="mb-1" + > + <b-card-group deck> + <overview-server /> + <overview-firmware /> + </b-card-group> + <b-card-group deck> + <overview-network /> + <overview-power /> + </b-card-group> + </page-section> + <page-section :section-title="$t('pageOverview.statusInformation')"> + <b-card-group deck> + <overview-events /> + <overview-inventory /> + <overview-dumps v-if="showDumps" /> + </b-card-group> </page-section> </b-container> </template> <script> -import OverviewQuickLinks from './OverviewQuickLinks'; -import OverviewEvents from './OverviewEvents'; +import LoadingBarMixin from '@/components/Mixins/LoadingBarMixin'; +import OverviewDumps from './OverviewDumps.vue'; +import OverviewEvents from './OverviewEvents.vue'; +import OverviewFirmware from './OverviewFirmware.vue'; +import OverviewInventory from './OverviewInventory.vue'; import OverviewNetwork from './OverviewNetwork'; -import PageTitle from '@/components/Global/PageTitle'; +import OverviewPower from './OverviewPower'; +import OverviewQuickLinks from './OverviewQuickLinks'; +import OverviewServer from './OverviewServer'; import PageSection from '@/components/Global/PageSection'; -import { mapState } from 'vuex'; -import LoadingBarMixin from '@/components/Mixins/LoadingBarMixin'; +import PageTitle from '@/components/Global/PageTitle'; export default { name: 'Overview', components: { - OverviewQuickLinks, + OverviewDumps, OverviewEvents, + OverviewFirmware, + OverviewInventory, OverviewNetwork, - PageTitle, + OverviewPower, + OverviewQuickLinks, + OverviewServer, PageSection, + PageTitle, }, mixins: [LoadingBarMixin], - computed: { - ...mapState({ - server: (state) => state.system.systems[0], - powerCapValue: (state) => state.powerControl.powerCapValue, - powerConsumptionValue: (state) => - state.powerControl.powerConsumptionValue, - serverManufacturer() { - if (this.server) return this.server.manufacturer || '--'; - return '--'; - }, - serverModel() { - if (this.server) return this.server.model || '--'; - return '--'; - }, - serverSerialNumber() { - if (this.server) return this.server.serialNumber || '--'; - return '--'; - }, - }), - activeHostFirmware() { - return this.$store.getters[`firmware/activeHostFirmware`]; - }, - hostFirmwareVersion() { - return this.activeHostFirmware?.version || '--'; - }, - activeBmcFirmware() { - return this.$store.getters[`firmware/activeBmcFirmware`]; - }, - bmcFirmwareVersion() { - return this.activeBmcFirmware?.version || '--'; - }, + data() { + return { + showDumps: process.env.VUE_APP_ENV_NAME === 'ibm', + }; }, created() { this.startLoader(); - const quicklinksPromise = new Promise((resolve) => { - this.$root.$on('overview-quicklinks-complete', () => resolve()); + const dumpsPromise = new Promise((resolve) => { + this.$root.$on('overview-dumps-complete', () => resolve()); + }); + const eventsPromise = new Promise((resolve) => { + this.$root.$on('overview-events-complete', () => resolve()); + }); + const firmwarePromise = new Promise((resolve) => { + this.$root.$on('overview-firmware-complete', () => resolve()); + }); + const inventoryPromise = new Promise((resolve) => { + this.$root.$on('overview-inventory-complete', () => resolve()); }); const networkPromise = new Promise((resolve) => { this.$root.$on('overview-network-complete', () => resolve()); }); - const eventsPromise = new Promise((resolve) => { - this.$root.$on('overview-events-complete', () => resolve()); + const powerPromise = new Promise((resolve) => { + this.$root.$on('overview-power-complete', () => resolve()); + }); + const quicklinksPromise = new Promise((resolve) => { + this.$root.$on('overview-quicklinks-complete', () => resolve()); }); + const serverPromise = new Promise((resolve) => { + this.$root.$on('overview-server-complete', () => resolve()); + }); + Promise.all([ - this.$store.dispatch('system/getSystem'), - this.$store.dispatch(`firmware/getFirmwareInformation`), - this.$store.dispatch('powerControl/getPowerControl'), - quicklinksPromise, - networkPromise, + dumpsPromise, eventsPromise, + firmwarePromise, + inventoryPromise, + networkPromise, + powerPromise, + quicklinksPromise, + serverPromise, ]).finally(() => this.endLoader()); }, }; </script> - -<style lang="scss" scoped> -.quicklinks-section { - margin-bottom: $spacer * 2; - margin-left: $spacer * -1; -} -</style> |