79 lines
2.6 KiB
Vue
79 lines
2.6 KiB
Vue
<template>
|
|
<div class="p-2">
|
|
<div v-if="modal" class="modal-container" @click="modal = ! modal"></div>
|
|
<div v-if="modal" class="modal px-2">
|
|
<p class="m-1 text-center">Add a new to-do list ?</p>
|
|
<InputField name="name" label="Title" placeholder="Your Title" required @update:field="name = $event" :errors="errors" />
|
|
<div class="flex-center m-1 mt-2">
|
|
<button class="btn-secondary mr-2" @click="modal = ! modal">Cancel</button>
|
|
<button class="btn-primary" @click="create">Create</button>
|
|
</div>
|
|
</div>
|
|
<div class="flex-between flex-center mb-1">
|
|
<a href="#" class="btn" @click="$router.back()">Back</a>
|
|
|
|
<a href="#" class="btn-primary" @click="modal = ! modal">Add New List</a>
|
|
</div>
|
|
<Loader v-if="loading" />
|
|
<div v-else class="flex flex-wrap -m-2 mt-2">
|
|
<div v-if="toDoLists.length < 1">No List Yet</div>
|
|
<ToDoList v-else
|
|
v-for="(toDoList, index) in toDoLists"
|
|
:key="index"
|
|
:to-do-list="toDoList"
|
|
class="w-full sm:w-1/2 md:w-1/3 lg:w-1/4" />
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import Loader from '../../components/Loader'
|
|
import InputField from '../../components/InputField'
|
|
import ToDoList from './ToDoList'
|
|
|
|
export default {
|
|
name: 'ToDoListIndex',
|
|
components: {
|
|
Loader, InputField, ToDoList
|
|
},
|
|
data: function () {
|
|
return {
|
|
loading: true,
|
|
modal: false,
|
|
toDoLists: null,
|
|
name: '',
|
|
errors: null,
|
|
}
|
|
},
|
|
mounted() {
|
|
// eslint-disable-next-line no-undef
|
|
axios.get('/api/to-do-lists')
|
|
.then(res => {
|
|
this.toDoLists = res.data.data
|
|
this.loading = false
|
|
})
|
|
.catch(errorRes => {
|
|
this.loading = false
|
|
if (errorRes.response.status === 404) {
|
|
this.$router.push('/')
|
|
}
|
|
})
|
|
},
|
|
methods: {
|
|
create: function () {
|
|
// eslint-disable-next-line no-undef
|
|
axios.post('/api/to-do-lists', {name: this.name})
|
|
.then(res => {
|
|
console.log(res)
|
|
this.modal = false
|
|
this.name = ''
|
|
this.toDoLists.push(res.data)
|
|
})
|
|
.catch(errorRes => {
|
|
console.log('Internal Error, Unable to delete contact.' + errorRes)
|
|
})
|
|
}
|
|
}
|
|
}
|
|
</script>
|