tiefen_space_web/app/[user_id]/page.jsx

136 lines
4.3 KiB
React
Raw Normal View History

2024-01-03 01:07:16 +08:00
"use client";
import React, { useState, useEffect } from "react";
import AuthBar from "@/components/AuthBar";
import WechatBar from "./_components/WechatBar";
import baseRequest from "@/utils/baseRequest";
import { Toast } from "antd-mobile";
2024-01-05 23:30:44 +08:00
import InOtherApp from "@/components/InOtherApp";
2024-01-03 01:07:16 +08:00
import { generateSignature } from "@/utils/crypto";
import Image from "next/image";
import verification from "@/public/icon/verification.png";
2024-01-05 23:30:44 +08:00
import icon_border from "@/public/images/icon_border.png";
import zone from "@/public/images/zone.png";
2024-01-05 23:30:44 +08:00
import Link from "next/link";
2024-01-12 20:43:37 +08:00
import { setCookie } from "cookies-next";
import copy from "@/utils/copy";
2024-05-06 23:17:23 +08:00
import { useRouter } from "next/navigation";
import { checkAuth } from "@/utils/auth";
2024-01-03 01:07:16 +08:00
export default function StreamerDetail({ params }) {
//页面数据
const [data, setData] = useState({});
useEffect(() => {
const getData = async () => {
try {
const base = baseRequest();
const signature = generateSignature({
user_id: parseInt(params.user_id, 10),
...base,
});
const detailResponse = await fetch(
`/api/streamer/list_ext_by_user_id?signature=${signature}`,
{
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify({
user_id: parseInt(params.user_id, 10),
...base,
}),
}
);
const detailData = await detailResponse.json();
2024-04-30 17:55:08 +08:00
console.log(detailData);
2024-01-03 01:07:16 +08:00
if (detailData.ret === -1) {
Toast.show({
content: detailData.msg,
});
return;
}
setData(detailData.data.streamer_ext);
} catch (error) {
console.error(error);
}
};
getData();
}, []);
2024-01-12 20:43:37 +08:00
2024-05-06 23:17:23 +08:00
const router = useRouter();
const [name, setName] = useState("");
const [content, setContent] = useState("");
const handleSubmit = async (e) => {
e.preventDefault();
const isLogined = await checkAuth();
if (!isLogined) {
Toast.show({
content: "请先登录",
});
return;
}
router.push("/pay");
2024-01-12 20:43:37 +08:00
};
2024-01-03 01:07:16 +08:00
return (
<section className="flex flex-1 flex-col container relative">
<InOtherApp />
<div className="absolute top-0 left-0 w-full">
<div className="flex relative h-64 overflow-hidden">
2024-01-03 01:07:16 +08:00
<img
2024-05-06 23:17:23 +08:00
src={data?.avatar?.images[0].urls[0]}
2024-01-03 01:07:16 +08:00
alt=""
className="w-full object-cover opacity-30"
2024-01-03 01:07:16 +08:00
/>
<div className="absolute top-0 left-0 w-full h-64 bg-gradient-to-t from-[#07050A] to-[#00000000]"></div>
</div>
</div>
2024-01-23 18:29:48 +08:00
<div className="flex flex-col flex-1 px-4 pt-2 pb-24 z-10">
2024-05-06 23:17:23 +08:00
<AuthBar />
2024-04-30 17:50:45 +08:00
<div className="flex flex-col items-center mt-24 mb-4">
2024-01-03 01:07:16 +08:00
<div className="w-[74px] h-[74px] rounded-full overflow-hidden">
<img
src={data?.avatar?.images[0].urls[0]}
alt=""
className="w-full object-cover"
/>
</div>
<div className="flex flex-row items-center mt-3">
<p className="text-white text-2xl font-medium mr-1">{data?.name}</p>
<Image src={verification} alt="" className="w-6 h-6" />
</div>
</div>
2024-05-06 23:17:23 +08:00
<form className="flex flex-col items-center" onSubmit={handleSubmit}>
<p className="text-white text-base mt-2 w-full max-w-sm">
您的昵称
</p>
<input
type="text"
name="name"
placeholder="请输入您的昵称"
value={name}
onChange={(e) => setName(e.target.value)}
className="input input-bordered input-md input-primary w-full max-w-sm"
/>
<p className="text-white text-base mt-2 w-full max-w-sm">
想要的祝福语
2024-01-05 23:30:44 +08:00
</p>
2024-05-06 23:17:23 +08:00
<input
type="text"
name="content"
placeholder="请输入你想要的祝福语"
value={content}
onChange={(e) => setContent(e.target.value)}
className="input input-bordered input-md input-primary w-full max-w-sm"
/>
<button className="btn btn-primary text-white rounded-full w-full max-w-sm mt-2">
提交
</button>
</form>
2024-01-05 23:30:44 +08:00
</div>
2024-01-03 01:07:16 +08:00
</section>
);
}