summaryrefslogtreecommitdiff
path: root/src/views/Overview/OverviewQuickLinks.vue
blob: f36c264f2fc082eedd36d126d01d004a3f610d22 (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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
<template>
  <div class="quicklinks">
    <div>
      <dl>
        <!-- TODO: display timezone -->
        <dt>BMC time</dt>
        <dd>{{ bmcTime | date('DD MMM YYYY HH:MM:SS') }}</dd>
      </dl>
    </div>
    <div>
      <!-- TODO: add toggle LED on/off funtionality -->
      <dl>
        <dt>Server LED</dt>
        <dd>
          <b-form-checkbox
            v-model="serverLEDChecked"
            name="check-button"
            switch
          >
            <span v-if="!serverLEDChecked">On</span>
            <span v-else>Off</span>
          </b-form-checkbox>
        </dd>
      </dl>
    </div>
    <div>
      <!-- TODO: link to network settings -->
      <b-button
        href="#"
        variant="secondary"
        class="d-flex justify-content-between align-items-center"
      >
        <span>Edit network settings</span>
        <icon-arrow-right />
      </b-button>
    </div>
    <div>
      <!-- TODO: link to SOL -->
      <b-button
        href="#"
        variant="secondary"
        class="d-flex justify-content-between align-items-center"
      >
        <span>Serial over LAN console</span>
        <icon-arrow-right />
      </b-button>
    </div>
  </div>
</template>

<script>
import ArrowRight16 from '@carbon/icons-vue/es/arrow--right/16';

export default {
  name: 'QuickLinks',
  components: {
    IconArrowRight: ArrowRight16
  },
  data() {
    return {
      serverLEDChecked: false
    };
  },
  computed: {
    bmcTime() {
      return this.$store.getters['global/bmcTime'];
    }
  },
  created() {
    this.getBmcTime();
  },
  methods: {
    getBmcTime() {
      this.$store.dispatch('global/getBmcTime');
    }
  }
};
</script>

<style lang="scss" scoped>
dd,
dl {
  margin: 0;
}

.quicklinks {
  background: $white;
  display: grid;
  grid-gap: 1rem;
  padding: 1rem;
  white-space: nowrap;
}

@media screen and (min-width: 600px) {
  .quicklinks {
    grid-template-columns: 1fr 1fr;
  }
}

@media screen and (min-width: 1095px) {
  .quicklinks {
    grid-template-columns: 1fr 1fr 1fr 1fr;
  }
}
</style>