hippofish/packages/client/src/pages/explore.users.vue

264 lines
5.6 KiB
Vue
Raw Normal View History

<template>
2023-04-08 02:01:42 +02:00
<MkSpacer :content-max="1200">
<MkTab v-model="origin" style="margin-bottom: var(--margin)">
<option value="local">{{ i18n.ts.local }}</option>
<option value="remote">{{ i18n.ts.remote }}</option>
</MkTab>
<div v-if="origin === 'local'">
<template v-if="tag == null">
<MkFolder class="_gap" persist-key="explore-pinned-users">
<template #header
><i
:class="icon('ph-bookmark ph-fw')"
2023-04-08 02:01:42 +02:00
style="margin-right: 0.5em"
></i
>{{ i18n.ts.pinnedUsers }}</template
>
<XUserList :pagination="pinnedUsers" />
</MkFolder>
<MkFolder
v-if="isSignedIn"
2023-04-08 02:01:42 +02:00
class="_gap"
persist-key="explore-popular-users"
>
<template #header
><i
:class="icon('ph-chart-line-up ph-fw')"
2023-04-08 02:01:42 +02:00
style="margin-right: 0.5em"
></i
>{{ i18n.ts.popularUsers }}</template
>
<XUserList :pagination="popularUsers" />
</MkFolder>
<MkFolder
v-if="isSignedIn"
2023-04-08 02:01:42 +02:00
class="_gap"
persist-key="explore-recently-updated-users"
>
<template #header
><i
:class="icon('ph-activity ph-fw')"
2023-04-08 02:01:42 +02:00
style="margin-right: 0.5em"
></i
>{{ i18n.ts.recentlyUpdatedUsers }}</template
>
<XUserList :pagination="recentlyUpdatedUsers" />
</MkFolder>
<MkFolder
v-if="isSignedIn"
2023-04-08 02:01:42 +02:00
class="_gap"
persist-key="explore-recently-registered-users"
>
<template #header
><i
:class="icon('ph-butterfly ph-fw')"
2023-04-08 02:01:42 +02:00
style="margin-right: 0.5em"
></i
>{{ i18n.ts.recentlyRegisteredUsers }}</template
>
<XUserList :pagination="recentlyRegisteredUsers" />
</MkFolder>
</template>
</div>
<div v-else>
<MkFolder
ref="tagsEl"
:foldable="true"
:expanded="false"
class="_gap"
>
<template #header
><i
:class="icon('ph-compass ph-fw')"
2023-04-08 02:01:42 +02:00
style="margin-right: 0.5em"
></i
>{{ i18n.ts.popularTags }}</template
>
2023-04-08 02:01:42 +02:00
<div class="vxjfqztj">
<MkA
v-for="tag in tagsLocal"
:key="'local:' + tag.tag"
2023-04-20 06:00:01 +02:00
:to="`/tags/${tag.tag}`"
2023-04-08 02:01:42 +02:00
class="local"
>{{ tag.tag }}</MkA
>
<MkA
v-for="tag in tagsRemote"
:key="'remote:' + tag.tag"
2023-04-20 06:00:01 +02:00
:to="`/tags/${tag.tag}`"
2023-04-08 02:01:42 +02:00
>{{ tag.tag }}</MkA
>
</div>
</MkFolder>
2023-04-08 02:01:42 +02:00
<MkFolder v-if="tag != null" :key="`${tag}`" class="_gap">
<template #header
><i
:class="icon('ph-hash ph-fw')"
2023-04-08 02:01:42 +02:00
style="margin-right: 0.5em"
></i
>{{ tag }}</template
>
<XUserList :pagination="tagUsers" />
</MkFolder>
2023-04-08 02:01:42 +02:00
<template v-if="tag == null && isSignedIn">
2023-04-08 02:01:42 +02:00
<MkFolder class="_gap">
<template #header
><i
:class="icon('ph-chart-line-up ph-fw')"
2023-04-08 02:01:42 +02:00
style="margin-right: 0.5em"
></i
>{{ i18n.ts.popularUsers }}</template
>
<XUserList :pagination="popularUsersF" />
</MkFolder>
<MkFolder class="_gap">
<template #header
><i
:class="icon('ph-activity ph-fw')"
2023-04-08 02:01:42 +02:00
style="margin-right: 0.5em"
></i
>{{ i18n.ts.recentlyUpdatedUsers }}</template
>
<XUserList :pagination="recentlyUpdatedUsersF" />
</MkFolder>
<MkFolder class="_gap">
<template #header
><i
:class="icon('ph-rocket-launch ph-fw')"
2023-04-08 02:01:42 +02:00
style="margin-right: 0.5em"
></i
>{{ i18n.ts.recentlyDiscoveredUsers }}</template
>
<XUserList :pagination="recentlyRegisteredUsersF" />
</MkFolder>
</template>
</div>
</MkSpacer>
</template>
<script lang="ts" setup>
2023-09-02 01:27:33 +02:00
import { computed, ref, watch } from "vue";
2023-04-08 02:01:42 +02:00
import XUserList from "@/components/MkUserList.vue";
import MkFolder from "@/components/MkFolder.vue";
import MkTab from "@/components/MkTab.vue";
import * as os from "@/os";
import { i18n } from "@/i18n";
2024-03-07 03:06:45 +01:00
import { isSignedIn } from "@/me";
import icon from "@/scripts/icon";
const props = defineProps<{
2023-04-08 02:01:42 +02:00
tag?: string;
}>();
const origin = ref("local");
const tagsEl = ref<InstanceType<typeof MkFolder>>();
const tagsLocal = ref([]);
const tagsRemote = ref([]);
2022-11-15 03:15:01 +01:00
2023-04-08 02:01:42 +02:00
watch(
() => props.tag,
() => {
if (tagsEl.value) tagsEl.value.toggleContent(props.tag == null);
2023-07-06 03:28:27 +02:00
},
2023-04-08 02:01:42 +02:00
);
const tagUsers = computed(() => ({
2023-04-08 02:01:42 +02:00
endpoint: "hashtags/users" as const,
limit: 30,
params: {
tag: props.tag,
2023-04-08 02:01:42 +02:00
origin: "combined",
sort: "+follower",
},
}));
2023-04-08 02:01:42 +02:00
const pinnedUsers = { endpoint: "pinned-users" };
const popularUsers = {
endpoint: "users",
limit: 10,
noPaging: true,
params: {
state: "alive",
origin: "local",
sort: "+follower",
},
};
const recentlyUpdatedUsers = {
endpoint: "users",
limit: 10,
noPaging: true,
params: {
origin: "local",
sort: "+updatedAt",
},
};
const recentlyRegisteredUsers = {
endpoint: "users",
limit: 10,
noPaging: true,
params: {
origin: "local",
state: "alive",
sort: "+createdAt",
},
};
const popularUsersF = {
endpoint: "users",
limit: 10,
noPaging: true,
params: {
state: "alive",
origin: "remote",
sort: "+follower",
},
};
const recentlyUpdatedUsersF = {
endpoint: "users",
limit: 10,
noPaging: true,
params: {
origin: "combined",
sort: "+updatedAt",
},
};
const recentlyRegisteredUsersF = {
endpoint: "users",
limit: 10,
noPaging: true,
params: {
origin: "combined",
sort: "+createdAt",
},
};
2023-04-08 02:01:42 +02:00
os.api("hashtags/list", {
sort: "+attachedLocalUsers",
attachedToLocalUserOnly: true,
limit: 30,
2023-04-08 02:01:42 +02:00
}).then((tags) => {
tagsLocal.value = tags;
});
2023-04-08 02:01:42 +02:00
os.api("hashtags/list", {
sort: "+attachedRemoteUsers",
attachedToRemoteUserOnly: true,
limit: 30,
2023-04-08 02:01:42 +02:00
}).then((tags) => {
tagsRemote.value = tags;
});
</script>
2022-11-15 03:05:07 +01:00
<style lang="scss" scoped>
.vxjfqztj {
> * {
margin-right: 16px;
2022-11-15 03:05:07 +01:00
&.local {
font-weight: bold;
}
}
2022-11-15 03:05:07 +01:00
}
</style>