"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"; import InOtherApp from "@/components/InOtherApp"; import { generateSignature } from "@/utils/crypto"; import Image from "next/image"; import verification from "@/public/icon/verification.png"; import icon_border from "@/public/images/icon_border.png"; import Link from "next/link"; import { setCookie } from "cookies-next"; import copy from "@/utils/copy"; 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(); if (detailData.ret === -1) { Toast.show({ content: detailData.msg, }); return; } setData(detailData.data.streamer_ext); } catch (error) { console.error(error); } }; getData(); }, []); //将主播链接复制到剪贴板,并存cookie const copyAndSetCookieInviter = () => { setCookie("inviter", data?.user_id); copy( `【${data?.name}】『ID:${data?.user_id}』,复制此条消息,打开铁粉空间APP,查看详情https://tiefen.fun/${data?.user_id}` ); }; return ( <section className="flex flex-1 flex-col container relative"> <InOtherApp /> <div className="absolute top-0 left-0 w-full"> <div className="relative"> <img src={data?.cover?.images[0].urls[0]} alt="" className="w-full h-64 object-cover object-center opacity-30" /> <div className="absolute top-0 left-0 w-full h-64 bg-gradient-to-t from-[#07050A] to-[#00000000]"></div> </div> </div> <div className="flex flex-col flex-1 px-4 pt-2 pb-24 z-10"> <AuthBar onNotLoginedClick={copyAndSetCookieInviter} /> <div className="flex flex-col items-center mt-24"> <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> <p className="text-secondary text-sm text-center font-medium mt-3 px-4"> {data?.bio} </p> </div> <WechatBar price={Math.ceil(data?.wechat_coin_price / 9)} streamerMid={data?.mid} auto_response_message={data?.auto_response_message} onClickDownloadApp={copyAndSetCookieInviter} /> {data?.platforms?.map((item, index) => ( <div key={index} onClick={() => window.open(item.url, "_blank")} className="flex flex-row cursor-pointer bg-[#07050A] border-2 border-[#FFFFFF26] rounded-2xl h-12 items-center justify-center mt-4" > <img src={item.icon.images[0].urls[0]} alt="" className="w-5 h-5" /> <p className="text-white text-base font-medium ml-2"> {item.link_name}|{item.nickname} </p> </div> ))} </div> <div className="flex flex-row items-center bg-[#13121F] fixed bottom-0 left-0 w-full rounded-t-2xl z-20 p-4"> <Image src={icon_border} alt="" className="w-12 h-12" /> <div className="flex flex-col flex-1 ml-4"> <p className="text-white text-base font-medium">铁粉空间</p> <p className="text-secondary text-sm font-medium">下载APP探索更多</p> </div> <Link className="p-2 pr-0" href="/" onClick={copyAndSetCookieInviter}> <p className="btn btn-sm bg-gradient-to-r from-[#FF668B] to-[#FF66F0] rounded-full text-white font-medium"> 立即下载 </p> </Link> </div> </section> ); }