yunohost-portal/pages/index.vue

64 lines
1.5 KiB
Vue
Raw Normal View History

2023-07-19 18:42:05 +02:00
<script setup lang="ts">
const userData = await useUserInfo()
2023-07-19 18:42:05 +02:00
const me = computed(() => {
const appTileColors = [
'red',
'orange',
'yellow',
'lime',
'green',
'teal',
'indigo',
'sky',
'purple',
'rose',
]
if (!userData.value) return
return {
...userData.value,
apps: Object.entries(userData.value.apps).map(([id, app]) => {
return {
...app,
id,
color: appTileColors[parseInt(app.label, 36) % appTileColors.length],
}
}),
}
})
2023-07-19 18:42:05 +02:00
</script>
2023-07-12 04:52:58 +02:00
2023-07-19 18:42:05 +02:00
<template>
<div v-if="me">
2023-07-19 18:42:05 +02:00
<div id="apps" class="p-10">
<div v-if="!me.apps.length">
2023-07-19 18:42:05 +02:00
<em class="text-gray-400"
>There is no app to list here, either because no web app yet is
installed on the server, or because you don't have access to any.
Please check with the admins of the server for more infos!</em
>
</div>
<ul v-else class="flex space-x-4">
2023-07-19 18:42:05 +02:00
<!-- NB : because of the usage of dynamic colors, gotta force tailwind to expose those, cf 'safelisting' -->
<li
v-for="app in me.apps"
:key="app.id"
:class="
'text-center leading-none p-5 card h-32 w-32 bg-' +
app.color +
'-500'
"
>
<a>
<div class="text-6xl font-extrabold">
{{ app.label.substring(0, 2) }}
2023-07-12 04:52:58 +02:00
</div>
2023-07-19 18:42:05 +02:00
<span class="leading-tight">{{ app.label }}</span>
</a>
</li>
</ul>
2023-07-12 04:52:58 +02:00
</div>
2023-07-19 18:42:05 +02:00
</div>
2023-07-12 04:52:58 +02:00
</template>