tiefen_space_h5/app/page.js

146 lines
4.3 KiB
JavaScript
Raw Normal View History

2024-06-24 22:12:13 +08:00
"use client";
import React, { useEffect, useRef, useState, Suspense } from "react";
2024-06-25 20:18:37 +08:00
import {
Tabs,
Swiper,
PullToRefresh,
Toast,
InfiniteScroll,
List,
2024-06-25 22:47:18 +08:00
Image,
2024-06-25 20:18:37 +08:00
} from "antd-mobile";
2024-06-25 20:18:37 +08:00
import PostItem from "../components/PostItem";
import { sleep } from "antd-mobile/es/utils/sleep";
import "./index.css";
2024-06-25 22:47:18 +08:00
import PostItemSkeleton from "@/components/skeletons/PostItemSkeleton";
2024-06-29 12:07:37 +08:00
import Link from "next/link";
2024-07-03 19:59:39 +08:00
import requre from "@/utils/require";
import baseRequest from "@/utils/baseRequest";
import { generateSignature } from "@/utils/crypto";
2024-06-25 20:18:37 +08:00
const variables = {
"@active-line-color": "#f00", // 将主题色改为红色
};
2024-06-24 22:12:13 +08:00
const tabItems = [
2024-06-25 20:18:37 +08:00
{ key: "commend", title: "推荐" },
{ key: "follow", title: "关注" },
];
let count = 0;
2024-06-29 12:07:37 +08:00
2024-06-25 20:18:37 +08:00
// const scrollHeight = 700;
// const scrollHeight = window.innerHeight-126
2024-06-24 22:12:13 +08:00
export default function Home() {
2024-06-25 20:18:37 +08:00
const swiperRef = useRef(null);
const [activeIndex, setActiveIndex] = useState(0);
const [data, setData] = useState([]);
2024-07-03 19:59:39 +08:00
const [loading, setLoading] = useState(true);
2024-06-25 20:18:37 +08:00
const [hasMore, setHasMore] = useState(true);
const [scrollHeight, setScrollHeight] = useState(0);
2024-07-03 19:59:39 +08:00
const [commenPostList,setCommenPostList] = useState([])
2024-06-25 20:18:37 +08:00
// 获取屏幕高度
// const scrollHeight = 600;
useEffect(() => {
setScrollHeight(window.innerHeight - 126);
2024-07-03 19:59:39 +08:00
getPostList(2);
// getData(0)
}, []);
2024-06-25 20:18:37 +08:00
async function doRefresh() {
2024-07-03 19:59:39 +08:00
// await sleep(1000);
// Toast.show({
// icon: "fail",
// content: "刷新失败",
// });
// throw new Error("刷新失败");
getPostList(1);
2024-06-25 20:18:37 +08:00
}
async function loadMore() {
2024-07-03 19:59:39 +08:00
// const append = await getPostList(0);
// setData((val) => [...val, ...append]);
// setHasMore(append.length > 0);
2024-06-25 20:18:37 +08:00
}
2024-07-03 19:59:39 +08:00
const getPostList = async (type = 0) => {
const data = await requre("POST", "/api/moment/recomm_list", {
body: { op_type: type },
});
setLoading(false)
if (data.ret == -1) {
Toast.show({
icon: "fail",
content: "加载失败",
});
}else{
setCommenPostList(data.data.recomm_list)
}
console.log("res", data);
};
2024-06-24 22:12:13 +08:00
return (
2024-07-02 15:09:48 +08:00
<div className="h-screen">
<div className="flex justify-between items-center px-2 custom-tabs text-gray-400 sticky top-0 z-10 bg-deepBg">
2024-06-25 20:18:37 +08:00
<Tabs
2024-06-24 22:12:13 +08:00
activeKey={tabItems[activeIndex].key}
2024-06-25 20:18:37 +08:00
onChange={(key) => {
const index = tabItems.findIndex((item) => item.key === key);
setActiveIndex(index);
swiperRef.current?.swipeTo(index);
2024-06-24 22:12:13 +08:00
}}
>
2024-06-25 20:18:37 +08:00
{tabItems.map((item) => (
<Tabs.Tab
forceRender={false}
title={item.title}
key={item.key}
className="text-left"
/>
2024-06-24 22:12:13 +08:00
))}
</Tabs>
2024-07-03 19:59:39 +08:00
<Link
href="search"
className="w-9 h-9 flex items-center justify-center bg-[#FFFFFF1A] rounded-full"
>
<Image src="/icons/search.png" />
</Link>
2024-06-25 20:18:37 +08:00
</div>
<Swiper
className="overflow-visible"
direction="horizontal"
loop
indicator={() => null}
ref={swiperRef}
defaultIndex={activeIndex}
onIndexChange={(index) => {
setActiveIndex(index);
}}
>
<Swiper.Item>
<PullToRefresh onRefresh={doRefresh}>
<List className="px-4 overflow-y-auto scrollbarBox_hidden">
2024-07-03 19:59:39 +08:00
{loading && <div><PostItemSkeleton /><PostItemSkeleton /><PostItemSkeleton /></div>}
{commenPostList.map(item=><List.Item key={item.id} className="!p-0">
<PostItem
type="post"
data={item}
/>
</List.Item>)}
2024-06-25 20:18:37 +08:00
<InfiniteScroll loadMore={loadMore} hasMore={hasMore} />
</List>
</PullToRefresh>
</Swiper.Item>
<Swiper.Item>
<PullToRefresh onRefresh={doRefresh}>
2024-06-25 20:18:37 +08:00
<List
className="p-2 overflow-y-auto scrollbarBox_hidden"
style={{ maxHeight: `${scrollHeight}px` }}
>
<List.Item className="!p-0">
2024-07-03 19:59:39 +08:00
<PostItem follow={true} type="post" />
2024-06-25 20:18:37 +08:00
</List.Item>
<InfiniteScroll loadMore={loadMore} hasMore={hasMore} />
</List>
</PullToRefresh>
</Swiper.Item>
</Swiper>
2024-07-02 15:09:48 +08:00
</div>
2024-06-25 20:18:37 +08:00
);
2024-06-24 22:12:13 +08:00
}