63 lines
1.6 KiB
Vue
Raw Normal View History

<template>
<Loading :loading="loading" :message="error" type="danger">
<div class="block">
<router-link class="button" to="/new">
<Icon name="plus">New container</Icon>
</router-link>
</div>
<div v-if="containers.length" class="box">
<ul>
<li v-for="container in containers" :key="container.id">
<router-link :to="`/show/${container.name}`">
<Icon
:class="`has-text-${status_icon(container).type} m-2`"
:name="status_icon(container).name"
>{{ container.name }}</Icon
>
</router-link>
</li>
</ul>
</div>
</Loading>
</template>
<script lang="ts">
2024-11-03 19:14:47 +01:00
import axios, { AxiosError } from 'axios'
2024-11-03 23:10:21 +01:00
import type { Container } from '../types'
import Icon from '../components/Icon.vue'
import Loading from '../components/Loading.vue'
import { get_status_icon } from '../utils'
export default {
name: 'Home',
components: {
Icon,
Loading,
},
data() {
return {
2024-11-03 23:10:21 +01:00
containers: [] as Container[],
2024-11-03 19:14:47 +01:00
error: '',
loading: true,
}
},
async mounted() {
try {
2024-11-03 23:10:21 +01:00
const response = await axios.get<Container[]>('/api/containers')
2024-11-03 19:14:47 +01:00
this.containers = response.data
} catch (error) {
console.error(error)
2024-11-03 19:14:47 +01:00
this.error =
error instanceof AxiosError ? error.message : 'Error loading containers'
} finally {
this.loading = false
}
},
methods: {
status_icon(container: Container): { name: string; type: string } {
return get_status_icon(container.status)
},
},
}
</script>