| Yoshie Muranaka | b89a53c | 2020-06-15 13:25:46 -0700 | [diff] [blame] | 1 | <template> | 
|  | 2 | <page-section :section-title="$t('pageHardwareStatus.fans')"> | 
| Yoshie Muranaka | c069c67 | 2020-06-18 14:21:50 -0700 | [diff] [blame] | 3 | <b-row> | 
|  | 4 | <b-col sm="6" md="5" xl="4"> | 
| Dixsie Wolmers | 9b22b49 | 2020-09-07 21:26:06 -0500 | [diff] [blame] | 5 | <search | 
|  | 6 | @changeSearch="onChangeSearchInput" | 
|  | 7 | @clearSearch="onClearSearchInput" | 
|  | 8 | /> | 
| Yoshie Muranaka | c069c67 | 2020-06-18 14:21:50 -0700 | [diff] [blame] | 9 | </b-col> | 
| Sukanya Pandey | 9901096 | 2020-07-27 21:44:47 +0530 | [diff] [blame] | 10 | <b-col sm="6" md="3" xl="2"> | 
|  | 11 | <table-cell-count | 
|  | 12 | :filtered-items-count="filteredRows" | 
|  | 13 | :total-number-of-cells="fans.length" | 
|  | 14 | ></table-cell-count> | 
|  | 15 | </b-col> | 
| Yoshie Muranaka | c069c67 | 2020-06-18 14:21:50 -0700 | [diff] [blame] | 16 | </b-row> | 
| Yoshie Muranaka | b89a53c | 2020-06-15 13:25:46 -0700 | [diff] [blame] | 17 | <b-table | 
|  | 18 | sort-icon-left | 
|  | 19 | no-sort-reset | 
| SurenNeware | 5e25e28 | 2020-07-08 15:57:23 +0530 | [diff] [blame] | 20 | responsive="md" | 
| Yoshie Muranaka | b89a53c | 2020-06-15 13:25:46 -0700 | [diff] [blame] | 21 | sort-by="health" | 
| SurenNeware | 307382e | 2020-07-27 20:45:14 +0530 | [diff] [blame] | 22 | show-empty | 
| Yoshie Muranaka | b89a53c | 2020-06-15 13:25:46 -0700 | [diff] [blame] | 23 | :items="fans" | 
|  | 24 | :fields="fields" | 
|  | 25 | :sort-desc="true" | 
|  | 26 | :sort-compare="sortCompare" | 
| Yoshie Muranaka | c069c67 | 2020-06-18 14:21:50 -0700 | [diff] [blame] | 27 | :filter="searchFilter" | 
| SurenNeware | 307382e | 2020-07-27 20:45:14 +0530 | [diff] [blame] | 28 | :empty-text="$t('global.table.emptyMessage')" | 
| SurenNeware | 156a0e6 | 2020-08-28 19:20:03 +0530 | [diff] [blame] | 29 | :empty-filtered-text="$t('global.table.emptySearchMessage')" | 
| Sukanya Pandey | 9901096 | 2020-07-27 21:44:47 +0530 | [diff] [blame] | 30 | @filtered="onFiltered" | 
| Yoshie Muranaka | b89a53c | 2020-06-15 13:25:46 -0700 | [diff] [blame] | 31 | > | 
|  | 32 | <!-- Expand chevron icon --> | 
|  | 33 | <template v-slot:cell(expandRow)="row"> | 
| Dixsie Wolmers | 8313376 | 2020-07-15 08:45:19 -0500 | [diff] [blame] | 34 | <b-button | 
|  | 35 | variant="link" | 
|  | 36 | data-test-id="hardwareStatus-button-expandFans" | 
|  | 37 | @click="row.toggleDetails" | 
|  | 38 | > | 
| Yoshie Muranaka | b89a53c | 2020-06-15 13:25:46 -0700 | [diff] [blame] | 39 | <icon-chevron /> | 
|  | 40 | </b-button> | 
|  | 41 | </template> | 
|  | 42 |  | 
|  | 43 | <!-- Health --> | 
|  | 44 | <template v-slot:cell(health)="{ value }"> | 
|  | 45 | <status-icon :status="statusIcon(value)" /> | 
|  | 46 | {{ value }} | 
|  | 47 | </template> | 
|  | 48 |  | 
|  | 49 | <template v-slot:row-details="{ item }"> | 
|  | 50 | <b-container fluid> | 
|  | 51 | <b-row> | 
|  | 52 | <b-col sm="6" xl="4"> | 
|  | 53 | <dl> | 
|  | 54 | <!-- Status state --> | 
|  | 55 | <dt>{{ $t('pageHardwareStatus.table.statusState') }}:</dt> | 
|  | 56 | <dd>{{ tableFormatter(item.statusState) }}</dd> | 
|  | 57 | </dl> | 
|  | 58 | </b-col> | 
|  | 59 | </b-row> | 
|  | 60 | </b-container> | 
|  | 61 | </template> | 
|  | 62 | </b-table> | 
|  | 63 | </page-section> | 
|  | 64 | </template> | 
|  | 65 |  | 
|  | 66 | <script> | 
|  | 67 | import PageSection from '@/components/Global/PageSection'; | 
|  | 68 | import IconChevron from '@carbon/icons-vue/es/chevron--down/20'; | 
| Sukanya Pandey | 9901096 | 2020-07-27 21:44:47 +0530 | [diff] [blame] | 69 | import TableCellCount from '@/components/Global/TableCellCount'; | 
| Yoshie Muranaka | b89a53c | 2020-06-15 13:25:46 -0700 | [diff] [blame] | 70 |  | 
|  | 71 | import StatusIcon from '@/components/Global/StatusIcon'; | 
| Yoshie Muranaka | 386df45 | 2020-06-18 12:45:13 -0700 | [diff] [blame] | 72 | import TableDataFormatterMixin from '@/components/Mixins/TableDataFormatterMixin'; | 
| Yoshie Muranaka | b89a53c | 2020-06-15 13:25:46 -0700 | [diff] [blame] | 73 | import TableSortMixin from '@/components/Mixins/TableSortMixin'; | 
| Yoshie Muranaka | c069c67 | 2020-06-18 14:21:50 -0700 | [diff] [blame] | 74 | import Search from '@/components/Global/Search'; | 
| Dixsie Wolmers | 9b22b49 | 2020-09-07 21:26:06 -0500 | [diff] [blame] | 75 | import SearchFilterMixin from '@/components/Mixins/SearchFilterMixin'; | 
| Yoshie Muranaka | b89a53c | 2020-06-15 13:25:46 -0700 | [diff] [blame] | 76 |  | 
|  | 77 | export default { | 
| Sukanya Pandey | 9901096 | 2020-07-27 21:44:47 +0530 | [diff] [blame] | 78 | components: { IconChevron, PageSection, StatusIcon, Search, TableCellCount }, | 
| Dixsie Wolmers | 9b22b49 | 2020-09-07 21:26:06 -0500 | [diff] [blame] | 79 | mixins: [TableDataFormatterMixin, TableSortMixin, SearchFilterMixin], | 
| Yoshie Muranaka | b89a53c | 2020-06-15 13:25:46 -0700 | [diff] [blame] | 80 | data() { | 
|  | 81 | return { | 
|  | 82 | fields: [ | 
|  | 83 | { | 
|  | 84 | key: 'expandRow', | 
|  | 85 | label: '', | 
|  | 86 | tdClass: 'table-row-expand', | 
|  | 87 | sortable: false | 
|  | 88 | }, | 
|  | 89 | { | 
|  | 90 | key: 'id', | 
|  | 91 | label: this.$t('pageHardwareStatus.table.id'), | 
|  | 92 | formatter: this.tableFormatter, | 
|  | 93 | sortable: true | 
|  | 94 | }, | 
|  | 95 | { | 
|  | 96 | key: 'health', | 
|  | 97 | label: this.$t('pageHardwareStatus.table.health'), | 
|  | 98 | formatter: this.tableFormatter, | 
|  | 99 | sortable: true | 
|  | 100 | }, | 
|  | 101 | { | 
|  | 102 | key: 'partNumber', | 
|  | 103 | label: this.$t('pageHardwareStatus.table.partNumber'), | 
|  | 104 | formatter: this.tableFormatter, | 
|  | 105 | sortable: true | 
|  | 106 | }, | 
|  | 107 | { | 
|  | 108 | key: 'serialNumber', | 
|  | 109 | label: this.$t('pageHardwareStatus.table.serialNumber'), | 
|  | 110 | formatter: this.tableFormatter, | 
|  | 111 | sortable: true | 
|  | 112 | } | 
| Yoshie Muranaka | c069c67 | 2020-06-18 14:21:50 -0700 | [diff] [blame] | 113 | ], | 
| Sukanya Pandey | 9901096 | 2020-07-27 21:44:47 +0530 | [diff] [blame] | 114 | searchTotalFilteredRows: 0 | 
| Yoshie Muranaka | b89a53c | 2020-06-15 13:25:46 -0700 | [diff] [blame] | 115 | }; | 
|  | 116 | }, | 
|  | 117 | computed: { | 
| Sukanya Pandey | 9901096 | 2020-07-27 21:44:47 +0530 | [diff] [blame] | 118 | filteredRows() { | 
|  | 119 | return this.searchFilter | 
|  | 120 | ? this.searchTotalFilteredRows | 
|  | 121 | : this.fans.length; | 
|  | 122 | }, | 
| Yoshie Muranaka | b89a53c | 2020-06-15 13:25:46 -0700 | [diff] [blame] | 123 | fans() { | 
|  | 124 | return this.$store.getters['fan/fans']; | 
|  | 125 | } | 
|  | 126 | }, | 
|  | 127 | created() { | 
|  | 128 | this.$store.dispatch('fan/getFanInfo').finally(() => { | 
| Gunnar Mills | defc9e2 | 2020-07-07 20:29:03 -0500 | [diff] [blame] | 129 | // Emit initial data fetch complete to parent component | 
| Yoshie Muranaka | b89a53c | 2020-06-15 13:25:46 -0700 | [diff] [blame] | 130 | this.$root.$emit('hardwareStatus::fans::complete'); | 
|  | 131 | }); | 
|  | 132 | }, | 
|  | 133 | methods: { | 
|  | 134 | sortCompare(a, b, key) { | 
|  | 135 | if (key === 'health') { | 
|  | 136 | return this.sortStatus(a, b, key); | 
|  | 137 | } | 
| Yoshie Muranaka | c069c67 | 2020-06-18 14:21:50 -0700 | [diff] [blame] | 138 | }, | 
| Sukanya Pandey | 9901096 | 2020-07-27 21:44:47 +0530 | [diff] [blame] | 139 | onFiltered(filteredItems) { | 
|  | 140 | this.searchTotalFilteredRows = filteredItems.length; | 
| Yoshie Muranaka | b89a53c | 2020-06-15 13:25:46 -0700 | [diff] [blame] | 141 | } | 
|  | 142 | } | 
|  | 143 | }; | 
|  | 144 | </script> |