Starting update interface implementation
This commit is contained in:
@ -683,6 +683,39 @@ ul {
|
||||
opacity: 0.1;
|
||||
}
|
||||
|
||||
.no-update-icon {
|
||||
background-image: url("");
|
||||
width: 30px;
|
||||
height: 30px;
|
||||
display: block;
|
||||
margin-right: 10px;
|
||||
margin-top: 10px;
|
||||
background-size: cover;
|
||||
opacity: 0.1;
|
||||
}
|
||||
|
||||
.update-icon {
|
||||
background-image: url("");
|
||||
width: 30px;
|
||||
height: 30px;
|
||||
display: block;
|
||||
margin-right: 10px;
|
||||
margin-top: 10px;
|
||||
background-size: cover;
|
||||
opacity: 0.2;
|
||||
}
|
||||
|
||||
.fail-update-icon {
|
||||
background-image: url("");
|
||||
width: 30px;
|
||||
height: 30px;
|
||||
display: block;
|
||||
margin-right: 10px;
|
||||
margin-top: 10px;
|
||||
background-size: cover;
|
||||
opacity: 0.2;
|
||||
}
|
||||
|
||||
.off-icon:hover {
|
||||
opacity: 0.3;
|
||||
cursor:pointer;
|
||||
@ -691,4 +724,28 @@ ul {
|
||||
.quit-icon:hover {
|
||||
opacity: 0.3;
|
||||
cursor:pointer;
|
||||
}
|
||||
|
||||
.no-update-icon:hover {
|
||||
opacity: 0.3;
|
||||
cursor:pointer;
|
||||
}
|
||||
.fail-update-icon:hover {
|
||||
opacity: 0.3;
|
||||
cursor:pointer;
|
||||
}
|
||||
|
||||
.update-icon:hover {
|
||||
opacity: 0.4;
|
||||
cursor:pointer;
|
||||
}
|
||||
|
||||
.green-strong {
|
||||
font-weight: bold;
|
||||
color: #54dc4b;
|
||||
}
|
||||
|
||||
.orange-strong {
|
||||
font-weight: bold;
|
||||
color: #f57d16cf;
|
||||
}
|
@ -1,19 +1,22 @@
|
||||
<template>
|
||||
<div class="controls">
|
||||
<i class="off-icon" v-on:click="action('shutdown')" v-if="off_available && off_display"></i>
|
||||
<i class="quit-icon" v-on:click="action('quit')" v-if="quit_available && quit_display"></i>
|
||||
<div class="controls" v-if="display">
|
||||
<i class="off-icon" v-on:click="action('shutdown')" v-if="off_available"></i>
|
||||
<i class="quit-icon" v-on:click="action('quit')" v-if="quit_available"></i>
|
||||
<i :class="[ update_available ? 'update-icon' :'no-update-icon' ]" v-if="update_possibe" @click="$router.push({ name: 'update' })"></i>
|
||||
</div>
|
||||
</template>
|
||||
<script>
|
||||
import axios from 'axios'
|
||||
|
||||
export default {
|
||||
name: 'Controls',
|
||||
data: function (){
|
||||
return {
|
||||
off_available : false,
|
||||
off_display : false,
|
||||
display: true,
|
||||
update_available: false,
|
||||
update_possible: true,
|
||||
quit_available: false,
|
||||
quit_display : false
|
||||
off_available: false
|
||||
}
|
||||
},
|
||||
methods: {
|
||||
@ -25,6 +28,23 @@ export default {
|
||||
})
|
||||
.catch(error => { console.log(error) });
|
||||
},
|
||||
check_update: function() {
|
||||
axios.get('/api/update/check', { timeout: 60000 })
|
||||
.then(response => {
|
||||
if(response.data.status) {
|
||||
if(response.data.message == "A new version is available"){
|
||||
this.update_available = true
|
||||
this.update_possible = true
|
||||
} else if(response.data.message == "This is the latest version"){
|
||||
this.update_available = false
|
||||
this.update_possible = true
|
||||
}
|
||||
} else {
|
||||
this.update_possible = false
|
||||
}
|
||||
})
|
||||
.catch(error => { console.log(error) });
|
||||
},
|
||||
load_config: function() {
|
||||
axios.get(`/api/misc/config`, { timeout: 60000 })
|
||||
.then(response => {
|
||||
@ -36,17 +56,16 @@ export default {
|
||||
},
|
||||
watch: {
|
||||
$route (){
|
||||
if ( ["capture", "report"].includes(this.$router.currentRoute.name) || screen.height != window.innerHeight ){
|
||||
this.off_display = false;
|
||||
this.quit_display = false;
|
||||
if ( ["capture", "report", "update", "loader"].includes(this.$router.currentRoute.name)){
|
||||
this.display = false;
|
||||
} else {
|
||||
this.off_display = (this.off_available)? true : false;
|
||||
this.quit_display = (this.quit_available)? true : false;
|
||||
this.display = true;
|
||||
}
|
||||
}
|
||||
},
|
||||
created: function() {
|
||||
this.load_config()
|
||||
},
|
||||
this.load_config();
|
||||
this.check_update();
|
||||
}
|
||||
}
|
||||
</script>
|
@ -17,6 +17,12 @@ const routes = [
|
||||
component: () => import('../views/home.vue'),
|
||||
props: true
|
||||
},
|
||||
{
|
||||
path: '/update',
|
||||
name: 'update',
|
||||
component: () => import('../views/update.vue'),
|
||||
props: true
|
||||
},
|
||||
{
|
||||
path: '/wifi-select',
|
||||
name: 'wifi-select',
|
||||
|
74
app/frontend/src/views/update.vue
Normal file
74
app/frontend/src/views/update.vue
Normal file
@ -0,0 +1,74 @@
|
||||
<template>
|
||||
<div class="center">
|
||||
<div v-if="update_possible">
|
||||
<div v-if="update_available">
|
||||
<p><span class="orange-strong">TinyCheck needs to be updated.</span><br />
|
||||
<span v-if="!update_launched">Please click on the button below to update it.</span>
|
||||
<span v-else>The process can take few minutes, please wait...</span>
|
||||
</p>
|
||||
<button class="btn btn-primary" :class="[ update_launched ? 'loading' : '' ]" v-on:click="launch_update()">Update it now</button>
|
||||
</div>
|
||||
<div v-else>
|
||||
<p><span class="green-strong">Your TinyCheck instance is up-to-date!</span><br />You'll be redirected in few seconds.</p>
|
||||
</div>
|
||||
</div>
|
||||
<div v-else>
|
||||
<p><strong>You dont have Internet or the rights to update Tinycheck.</strong><br />You'll be redirected in few seconds.</p>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import axios from 'axios'
|
||||
|
||||
export default {
|
||||
name: 'update',
|
||||
data() {
|
||||
return {
|
||||
translation: {},
|
||||
update_available: null,
|
||||
update_possible: true,
|
||||
update_launched: null,
|
||||
check_interval: null
|
||||
}
|
||||
},
|
||||
methods: {
|
||||
check_update: function() {
|
||||
axios.get('/api/update/check', { timeout: 60000 })
|
||||
.then(response => {
|
||||
console.log(response.data.status)
|
||||
if(response.data.status) {
|
||||
if(response.data.message == "A new version is available"){
|
||||
this.update_available = true
|
||||
this.update_possible = true
|
||||
} else if (response.data.message == "This is the latest version"){
|
||||
this.update_available = false
|
||||
this.update_possible = true
|
||||
clearInterval(this.check_interval);
|
||||
setTimeout(function () { window.location.href = "/"; }.bind(this), 3000);
|
||||
}
|
||||
} else {
|
||||
this.update_possible = false
|
||||
setTimeout(function () { window.location.href = "/"; }.bind(this), 3000);
|
||||
}
|
||||
})
|
||||
.catch(error => { console.log(error) });
|
||||
},
|
||||
launch_update: function() {
|
||||
axios.get(`/api/update/process`, { timeout: 60000 })
|
||||
.then(response => {
|
||||
if(response.data.status) {
|
||||
if(response.data.message == "Update successfully launched"){
|
||||
this.update_launched = true
|
||||
this.check_interval = setInterval(function(){ this.check_update(); }.bind(this), 3000);
|
||||
}
|
||||
}
|
||||
})
|
||||
.catch(error => { console.log(error) });
|
||||
}
|
||||
},
|
||||
created: function() {
|
||||
this.check_update();
|
||||
}
|
||||
}
|
||||
</script>
|
Reference in New Issue
Block a user