Added task overview

This commit is contained in:
kolaente 2018-11-06 15:54:25 +01:00
parent d27b5d6870
commit 23dc41b501
No known key found for this signature in database
GPG key ID: F40E70337AB24C9B
3 changed files with 91 additions and 47 deletions

View file

@ -2,18 +2,33 @@
<div class="content has-text-centered"> <div class="content has-text-centered">
<h2>Hi {{user.infos.username}}!</h2> <h2>Hi {{user.infos.username}}!</h2>
<p>Click on a list or namespace on the left to get started.</p> <p>Click on a list or namespace on the left to get started.</p>
<p v-if="loading">Loading tasks...</p>
<h3 v-if="tasks && tasks.length > 0">Current tasks</h3>
<div class="box tasks" v-if="tasks && tasks.length > 0">
<div @click="gotoList(l.listID)" class="task" v-for="l in tasks" v-bind:key="l.id" v-if="!l.done">
<label v-bind:for="l.id">
<input type="checkbox" v-bind:id="l.id" disabled>
{{l.text}}
<i v-if="l.dueDate > 0"> - Due on {{formatUnixDate(l.dueDate)}}</i>
</label>
</div>
</div>
</div> </div>
</template> </template>
<script> <script>
import auth from '../auth' import auth from '../auth'
import router from '../router' import router from '../router'
import {HTTP} from '../http-common'
import message from '../message'
export default { export default {
name: "Home", name: "Home",
data() { data() {
return { return {
user: auth.user user: auth.user,
loading: false,
tasks: []
} }
}, },
beforeMount() { beforeMount() {
@ -22,14 +37,44 @@
router.push({name: 'login'}) router.push({name: 'login'})
} }
}, },
created() {
this.loadPendingTasks()
},
methods: { methods: {
logout() { logout() {
auth.logout() auth.logout()
} },
loadPendingTasks() {
this.loading = true
HTTP.get(`tasks`, {headers: {'Authorization': 'Bearer ' + localStorage.getItem('token')}})
.then(response => {
this.tasks = response.data
this.tasks.sort(this.sortyByDeadline)
this.loading = false
})
.catch(e => {
this.handleError(e)
})
},
formatUnixDate(dateUnix) {
return (new Date(dateUnix * 1000)).toLocaleString()
},
sortyByDeadline(a, b) {
return ((a.dueDate > b.dueDate) ? -1 : ((a.dueDate < b.dueDate) ? 1 : 0));
},
gotoList(lid) {
router.push({name: 'showList', params: {id: lid}})
},
handleError(e) {
this.loading = false
message.error(e, this)
}
}, },
} }
</script> </script>
<style scoped> <style scoped>
h3{
text-align: left;
}
</style> </style>

View file

@ -271,46 +271,3 @@
} }
} }
</script> </script>
<style scoped lang="scss">
.tasks {
margin-top: 1rem;
padding: 0;
.task {
display: block;
padding: 0.5rem 1rem;
border-bottom: 1px solid darken(#fff, 10%);
label{
width: 96%;
display: inline-block;
cursor: pointer;
}
input[type="checkbox"] {
vertical-align: middle;
}
.settings{
float: right;
width: 4%;
cursor: pointer;
}
}
.task:last-child {
border-bottom: none;
}
}
.taskedit{
min-height: calc(100% - 1rem);
margin-top: 1rem;
}
.settings{
float: right;
color: rgb(74, 74, 74);
}
</style>

View file

@ -150,3 +150,45 @@ h1,h2,h3,h4,h5,h6{
.buttonright { .buttonright {
margin-right: 0.5rem; margin-right: 0.5rem;
} }
.tasks {
margin-top: 1rem;
padding: 0;
text-align: left;
.task {
display: block;
padding: 0.5rem 1rem;
border-bottom: 1px solid darken(#fff, 10%);
label{
width: 96%;
display: inline-block;
cursor: pointer;
}
input[type="checkbox"] {
vertical-align: middle;
}
.settings{
float: right;
width: 4%;
cursor: pointer;
}
}
.task:last-child {
border-bottom: none;
}
}
.taskedit{
min-height: calc(100% - 1rem);
margin-top: 1rem;
}
.settings{
float: right;
color: rgb(74, 74, 74);
}