Add tag timeline page
This commit is contained in:
parent
41ac059936
commit
3310bb321a
3 changed files with 96 additions and 0 deletions
|
@ -59,6 +59,22 @@ export async function getHomeTimeline(
|
||||||
return data
|
return data
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export async function getTagTimeline(
|
||||||
|
authToken: string | null,
|
||||||
|
tagName: string,
|
||||||
|
maxId?: string,
|
||||||
|
): Promise<Post[]> {
|
||||||
|
const url = `${BACKEND_URL}/api/v1/timelines/tag/${tagName}`
|
||||||
|
const queryParams = { max_id: maxId, limit: PAGE_SIZE }
|
||||||
|
const response = await http(url, {
|
||||||
|
method: "GET",
|
||||||
|
queryParams,
|
||||||
|
authToken,
|
||||||
|
})
|
||||||
|
const data = await response.json()
|
||||||
|
return data
|
||||||
|
}
|
||||||
|
|
||||||
export async function getPostsByAuthor(
|
export async function getPostsByAuthor(
|
||||||
authToken: string | null,
|
authToken: string | null,
|
||||||
authorId: string,
|
authorId: string,
|
||||||
|
|
|
@ -10,6 +10,7 @@ import ProfileForm from "@/views/ProfileForm.vue"
|
||||||
import PostList from "@/views/PostList.vue"
|
import PostList from "@/views/PostList.vue"
|
||||||
import PostDetail from "@/views/PostDetail.vue"
|
import PostDetail from "@/views/PostDetail.vue"
|
||||||
import PostOverlay from "@/views/PostOverlay.vue"
|
import PostOverlay from "@/views/PostOverlay.vue"
|
||||||
|
import TagTimeline from "@/views/TagTimeline.vue"
|
||||||
import SearchResultList from "@/views/SearchResultList.vue"
|
import SearchResultList from "@/views/SearchResultList.vue"
|
||||||
|
|
||||||
import { useCurrentUser } from "@/store/user"
|
import { useCurrentUser } from "@/store/user"
|
||||||
|
@ -67,6 +68,12 @@ const routes: Array<RouteRecordRaw> = [
|
||||||
component: PostOverlay,
|
component: PostOverlay,
|
||||||
meta: { },
|
meta: { },
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
path: "/tag/:tagName",
|
||||||
|
name: "tag",
|
||||||
|
component: TagTimeline,
|
||||||
|
meta: { },
|
||||||
|
},
|
||||||
{
|
{
|
||||||
path: "/notifications",
|
path: "/notifications",
|
||||||
name: "notifications",
|
name: "notifications",
|
||||||
|
|
73
src/views/TagTimeline.vue
Normal file
73
src/views/TagTimeline.vue
Normal file
|
@ -0,0 +1,73 @@
|
||||||
|
<template>
|
||||||
|
<div id="main">
|
||||||
|
<div class="content posts">
|
||||||
|
<post-or-repost
|
||||||
|
v-for="post in posts"
|
||||||
|
:post="post"
|
||||||
|
:key="post.id"
|
||||||
|
@post-deleted="onPostDeleted($event)"
|
||||||
|
></post-or-repost>
|
||||||
|
<button
|
||||||
|
v-if="isPageFull()"
|
||||||
|
class="btn"
|
||||||
|
@click="loadNextPage()"
|
||||||
|
>
|
||||||
|
Show more posts
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
<sidebar></sidebar>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script setup lang="ts">
|
||||||
|
/* eslint-disable @typescript-eslint/no-unused-vars */
|
||||||
|
import { ref, onMounted } from "vue"
|
||||||
|
import { useRoute } from "vue-router"
|
||||||
|
|
||||||
|
import { PAGE_SIZE } from "@/api/common"
|
||||||
|
import { Post, getTagTimeline } from "@/api/posts"
|
||||||
|
import PostOrRepost from "@/components/PostOrRepost.vue"
|
||||||
|
import Sidebar from "@/components/Sidebar.vue"
|
||||||
|
import { useCurrentUser } from "@/store/user"
|
||||||
|
import { formatDate } from "@/utils/format"
|
||||||
|
|
||||||
|
const route = useRoute()
|
||||||
|
const posts = ref<Post[]>([])
|
||||||
|
|
||||||
|
onMounted(async () => {
|
||||||
|
const { authToken } = useCurrentUser()
|
||||||
|
posts.value = await getTagTimeline(
|
||||||
|
authToken.value,
|
||||||
|
route.params.tagName,
|
||||||
|
)
|
||||||
|
})
|
||||||
|
|
||||||
|
function onPostDeleted(postId: string) {
|
||||||
|
const postIndex = posts.value.findIndex((post) => post.id === postId)
|
||||||
|
posts.value.splice(postIndex, 1)
|
||||||
|
}
|
||||||
|
|
||||||
|
function isPageFull(): boolean {
|
||||||
|
return posts.value.length >= PAGE_SIZE
|
||||||
|
}
|
||||||
|
|
||||||
|
async function loadNextPage() {
|
||||||
|
if (posts.value.length > 0) {
|
||||||
|
const { authToken } = useCurrentUser()
|
||||||
|
const newPosts = await getTagTimeline(
|
||||||
|
authToken.value,
|
||||||
|
route.params.tagName,
|
||||||
|
posts.value[posts.value.length - 1].id,
|
||||||
|
)
|
||||||
|
posts.value.push(...newPosts)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped lang="scss">
|
||||||
|
@import "../styles/layout";
|
||||||
|
|
||||||
|
:deep(.post) {
|
||||||
|
margin-bottom: $block-outer-padding;
|
||||||
|
}
|
||||||
|
</style>
|
Loading…
Reference in a new issue