hippofish/packages/client/src/pages/admin/overview.users.vue
2023-04-07 17:01:42 -07:00

65 lines
1.2 KiB
Vue

<template>
<div :class="$style.root">
<Transition
:name="$store.state.animation ? '_transition_zoom' : ''"
mode="out-in"
>
<MkLoading v-if="fetching" />
<div v-else class="users">
<MkA
v-for="(user, i) in newUsers"
:key="user.id"
:to="`/user-info/${user.id}`"
class="user"
>
<MkUserCardMini :user="user" />
</MkA>
</div>
</Transition>
</div>
</template>
<script lang="ts" setup>
import { onMounted, onUnmounted, ref } from "vue";
import * as os from "@/os";
import { useInterval } from "@/scripts/use-interval";
import MkUserCardMini from "@/components/MkUserCardMini.vue";
let newUsers = $ref(null);
let fetching = $ref(true);
const fetch = async () => {
const _newUsers = await os.api("admin/show-users", {
limit: 5,
sort: "+createdAt",
origin: "local",
});
newUsers = _newUsers;
fetching = false;
};
useInterval(fetch, 1000 * 60, {
immediate: true,
afterMounted: true,
});
</script>
<style lang="scss" module>
.root {
&:global {
> .users {
.chart-move {
transition: transform 1s ease;
}
display: grid;
grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
grid-gap: 12px;
> .user:hover {
text-decoration: none;
}
}
}
}
</style>