summaryrefslogtreecommitdiff
path: root/src/views/_sila/SystemDescription/Info/InventoryTableSystem.vue
blob: 0c32d2c07a1141678c7c5e01edf446fe35bad41d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
<template>
  <page-section class="bootstrap-table__section">
    <b-table
      responsive="md"
      show-empty
      class="table-rounded"
      no-border-collapse
      :items="items"
      :fields="fields"
      :empty-text="$t('global.table.emptyMessage')"
    >
    </b-table>
  </page-section>
</template>

<script>
import BVToastMixin from '@/components/Mixins/BVToastMixin';
import PageSection from '@/components/Global/PageSection';
import LoadingBarMixin from '@/components/Mixins/LoadingBarMixin';
import TableRowExpandMixin, {
  expandRowLabel,
} from '@/components/Mixins/TableRowExpandMixin';

export default {
  components: { PageSection },
  mixins: [BVToastMixin, TableRowExpandMixin, LoadingBarMixin],
  data() {
    return {
      fields: [
        {
          key: 'param',
          label: 'Параметр',
          formatter: this.dataFormatter,
          thStyle: { width: '50%' },
        },
        {
          key: 'value',
          label: 'Значение',
          formatter: this.dataFormatter,
        },
      ],
      expandRowLabel: expandRowLabel,
      items: null,
    };
  },
  computed: {
    systems() {
      return this.$store.getters['system/systems'];
    },
  },
  watch: {
    systems() {
      this.items = [
        {
          param: 'id',
          value: this.id,
        },
        { param: 'Модель', value: this.systems[0].model },
        { param: 'Производитель', value: '' },
        { param: 'Операционная система', value: '' },
        { param: 'Серийный номер', value: this.systems[0].serialNumber },
        {
          param: 'Свободное место на Flash-накопителе',
          value: '1 024 000 Мб',
        },
      ];
    },
  },
  created() {
    this.$store.dispatch('system/getSystem').finally(() => {
      // Emit initial data fetch complete to parent component
      this.$root.$emit('hardware-status-system-complete');
    });
    this.startLoader();
    const systemTablePromise = new Promise((resolve) => {
      this.$root.$on('hardware-status-system-complete', () => resolve());
    });
    Promise.all([systemTablePromise]).finally(() => this.endLoader());
  },
};
</script>