Add refresh functionality in app header

Clicking refresh in the app header will update the :key
value for the router-view component, and trigger a
component re-render.

Signed-off-by: Yoshie Muranaka <yoshiemuranaka@gmail.com>
Change-Id: I15da6d2d04fc311dfc092fbe840add950180124f
diff --git a/src/components/AppHeader/AppHeader.vue b/src/components/AppHeader/AppHeader.vue
index d411c1f..e155a65 100644
--- a/src/components/AppHeader/AppHeader.vue
+++ b/src/components/AppHeader/AppHeader.vue
@@ -20,7 +20,7 @@
               Power
               <status-icon :status="hostStatusIcon" />
             </b-nav-item>
-            <b-nav-item>
+            <b-nav-item @click="refresh">
               Refresh
               <icon-renew />
             </b-nav-item>
@@ -84,6 +84,9 @@
     getEvents() {
       this.$store.dispatch('eventLog/getEventLogData');
     },
+    refresh() {
+      this.$emit('refresh');
+    },
     logout() {
       this.$store.dispatch('authentication/logout');
     }
diff --git a/src/layouts/AppLayout.vue b/src/layouts/AppLayout.vue
index e1bb410..33faa38 100644
--- a/src/layouts/AppLayout.vue
+++ b/src/layouts/AppLayout.vue
@@ -1,6 +1,6 @@
 <template>
   <div>
-    <app-header ref="focusTarget" />
+    <app-header ref="focusTarget" @refresh="refresh" />
     <b-container fluid class="page-container">
       <b-row no-gutters>
         <b-col tag="nav" cols="12" md="3" lg="2">
@@ -8,7 +8,7 @@
         </b-col>
         <b-col cols="12" md="9" lg="10">
           <page-container>
-            <router-view ref="routerView" />
+            <router-view ref="routerView" :key="routerKey" />
           </page-container>
         </b-col>
       </b-row>
@@ -27,6 +27,11 @@
     AppNavigation,
     PageContainer
   },
+  data() {
+    return {
+      routerKey: 0
+    };
+  },
   watch: {
     $route: function() {
       // $nextTick = DOM updated
@@ -45,6 +50,13 @@
         focusTarget.removeAttribute('tabindex');
       });
     }
+  },
+  methods: {
+    refresh() {
+      // Changing the component :key value will trigger
+      // a component re-rendering and 'refresh' the view
+      this.routerKey += 1;
+    }
   }
 };
 </script>