xref: /openbmc/webui-vue/src/views/HardwareStatus/Inventory/InventoryServiceIndicator.vue (revision db47b7e1f4b8174698b1894edabf57d022fac609)
1<template>
2  <page-section
3    :section-title="$t('pageInventory.systemIndicator.sectionTitle')"
4  >
5    <div class="form-background pl-4 pt-4 pb-1">
6      <b-row>
7        <b-col sm="6" md="3">
8          <dl>
9            <dt>{{ $t('pageInventory.systemIndicator.powerStatus') }}</dt>
10            <dd>
11              {{ $t(powerStatus) }}
12            </dd>
13          </dl>
14        </b-col>
15        <b-col sm="6" md="3">
16          <dl>
17            <dt>
18              {{ $t('pageInventory.systemIndicator.identifyLed') }}
19            </dt>
20            <dd>
21              <b-form-checkbox
22                id="identifyLedSwitchService"
23                v-model="systems.locationIndicatorActive"
24                data-test-id="inventoryService-toggle-identifyLed"
25                switch
26                @change="toggleIdentifyLedSwitch"
27              >
28                <span v-if="systems.locationIndicatorActive">
29                  {{ $t('global.status.on') }}
30                </span>
31                <span v-else>{{ $t('global.status.off') }}</span>
32              </b-form-checkbox>
33            </dd>
34          </dl>
35        </b-col>
36      </b-row>
37    </div>
38  </page-section>
39</template>
40<script>
41import PageSection from '@/components/Global/PageSection';
42import BVToastMixin from '@/components/Mixins/BVToastMixin';
43
44export default {
45  components: { PageSection },
46  mixins: [BVToastMixin],
47  computed: {
48    systems() {
49      let systemData = this.$store.getters['system/systems'][0];
50      return systemData ? systemData : {};
51    },
52    serverStatus() {
53      return this.$store.getters['global/serverStatus'];
54    },
55    powerStatus() {
56      if (this.serverStatus === 'unreachable') {
57        return `global.status.off`;
58      }
59      return `global.status.${this.serverStatus}`;
60    },
61  },
62  created() {
63    this.$store.dispatch('system/getSystem').finally(() => {
64      // Emit initial data fetch complete to parent component
65      this.$root.$emit('hardware-status-service-complete');
66    });
67  },
68  methods: {
69    toggleIdentifyLedSwitch(state) {
70      this.$store
71        .dispatch('system/changeIdentifyLedState', state)
72        .then((message) => this.successToast(message))
73        .catch(({ message }) => this.errorToast(message));
74    },
75  },
76};
77</script>
78