xref: /openbmc/webui-vue/src/views/HardwareStatus/Inventory/InventoryTableAssembly.vue (revision c4b8757ed88ecea369e6044548d2fbe072d5bd4a)
1<template>
2  <page-section :section-title="$t('pageInventory.assemblies')">
3    <b-table
4      sort-icon-left
5      no-sort-reset
6      hover
7      responsive="md"
8      :items="items"
9      :fields="fields"
10      show-empty
11      :empty-text="$t('global.table.emptyMessage')"
12    >
13      <!-- Expand chevron icon -->
14      <template #cell(expandRow)="row">
15        <b-button
16          variant="link"
17          data-test-id="hardwareStatus-button-expandAssembly"
18          :title="expandRowLabel"
19          class="btn-icon-only"
20          @click="toggleRowDetails(row)"
21        >
22          <icon-chevron />
23          <span class="sr-only">{{ expandRowLabel }}</span>
24        </b-button>
25      </template>
26
27      <!-- Toggle identify LED -->
28      <template #cell(identifyLed)="row">
29        <b-form-checkbox
30          v-if="hasIdentifyLed(row.item.identifyLed)"
31          v-model="row.item.identifyLed"
32          name="switch"
33          switch
34          @change="toggleIdentifyLedValue(row.item)"
35        >
36          <span v-if="row.item.identifyLed">
37            {{ $t('global.status.on') }}
38          </span>
39          <span v-else> {{ $t('global.status.off') }} </span>
40        </b-form-checkbox>
41        <div v-else>--</div>
42      </template>
43
44      <template #row-details="{ item }">
45        <b-container fluid>
46          <b-row>
47            <b-col class="mt-2" sm="6" xl="6">
48              <!-- Nmae -->
49              <dt>{{ $t('pageInventory.table.name') }}:</dt>
50              <dd>{{ dataFormatter(item.name) }}</dd>
51              <!-- Serial number -->
52              <dt>{{ $t('pageInventory.table.serialNumber') }}:</dt>
53              <dd>{{ dataFormatter(item.serialNumber) }}</dd>
54            </b-col>
55            <b-col class="mt-2" sm="6" xl="6">
56              <!-- Model-->
57              <dt>Model</dt>
58              <dd>{{ dataFormatter(item.model) }}</dd>
59              <!-- Spare Part Number -->
60              <dt>Spare Part Number</dt>
61              <dd>{{ dataFormatter(item.sparePartNumber) }}</dd>
62            </b-col>
63          </b-row>
64        </b-container>
65      </template>
66    </b-table>
67  </page-section>
68</template>
69
70<script>
71import PageSection from '@/components/Global/PageSection';
72import IconChevron from '@carbon/icons-vue/es/chevron--down/20';
73import BVToastMixin from '@/components/Mixins/BVToastMixin';
74import TableRowExpandMixin, {
75  expandRowLabel,
76} from '@/components/Mixins/TableRowExpandMixin';
77import DataFormatterMixin from '@/components/Mixins/DataFormatterMixin';
78
79export default {
80  components: { IconChevron, PageSection },
81  mixins: [BVToastMixin, TableRowExpandMixin, DataFormatterMixin],
82  data() {
83    return {
84      fields: [
85        {
86          key: 'expandRow',
87          label: '',
88          tdClass: 'table-row-expand',
89        },
90        {
91          key: 'id',
92          label: this.$t('pageInventory.table.id'),
93          formatter: this.dataFormatter,
94          sortable: true,
95        },
96        {
97          key: 'partNumber',
98          label: this.$t('pageInventory.table.partNumber'),
99          formatter: this.dataFormatter,
100          sortable: true,
101        },
102        {
103          key: 'locationNumber',
104          label: this.$t('pageInventory.table.locationNumber'),
105          formatter: this.dataFormatter,
106          sortable: true,
107        },
108        {
109          key: 'identifyLed',
110          label: this.$t('pageInventory.table.identifyLed'),
111          formatter: this.dataFormatter,
112        },
113      ],
114      expandRowLabel: expandRowLabel,
115    };
116  },
117  computed: {
118    assemblies() {
119      return this.$store.getters['assemblies/assemblies'];
120    },
121    items() {
122      if (this.assemblies) {
123        return this.assemblies;
124      } else {
125        return [];
126      }
127    },
128  },
129  created() {
130    this.$store.dispatch('assemblies/getAssemblyInfo').finally(() => {
131      // Emit initial data fetch complete to parent component
132      this.$root.$emit('hardware-status-assembly-complete');
133    });
134  },
135  methods: {
136    toggleIdentifyLedValue(row) {
137      this.$store
138        .dispatch('assemblies/updateIdentifyLedValue', {
139          uri: row.uri,
140          identifyLed: row.identifyLed,
141        })
142        .catch(({ message }) => this.errorToast(message));
143    },
144    hasIdentifyLed(identifyLed) {
145      return typeof identifyLed === 'boolean';
146    },
147  },
148};
149</script>
150