"use client"; import React, { useState, useEffect } from "react"; import baseRequest from "@/utils/baseRequest"; import { Toast } from "antd-mobile"; import { generateSignature } from "@/utils/crypto"; import Image from "next/image"; import html2canvas from "html2canvas"; export default function GenerateLink({ params }) { //生成二维码 const [qrcodeUrl, setQrcodeUrl] = useState(""); useEffect(() => { var QRCode = require("qrcode"); QRCode.toDataURL( `https://tiefen.fun/${params.user_id}`, function (err, url) { setQrcodeUrl(url); } ); }, []); //页面数据 const [isFetching, setIsFetching] = useState(true); 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); setIsFetching(false); } catch (error) { console.error(error); } }; getData(); }, []); //保存二维码 const saveQrcode = async () => { window.ReactNativeWebView.postMessage( JSON.stringify({ type: "SAVE_IMAGE", data: qrcodeUrl, }) ); }; //保存海报 const savePoster = async () => { const element = document.getElementById("print"); const canvas = await html2canvas(element, { useCORS: true, }); const data = canvas.toDataURL("image/jpg"); window.ReactNativeWebView.postMessage( JSON.stringify({ type: "SAVE_IMAGE", data: data, }) ); }; //复制链接 const copyUrl = () => { window.ReactNativeWebView.postMessage( JSON.stringify({ type: "COPY_URL", data: `https://tiefen.fun/${params.user_id}`, }) ); }; if (isFetching) { return ( <section className="flex flex-1 justify-center container"> <span className="absolute top-1/2 loading loading-spinner loading-lg"></span> </section> ); } return ( <section className="flex flex-1 flex-col container py-4"> <div className="flex flex-col gap-2"> <h1 className="text-white text-xl font-semibold text-center"> 已为您生成专属链接与分享海报 </h1> <p className="text-white text-base text-center"> 请保存您的分享链接或海报 </p> </div> <div className="flex flex-col gap-4 px-4 mt-4"> <button onClick={copyUrl} className="btn btn-primary text-white text-base" > 复制链接 </button> <button onClick={savePoster} className="btn btn-primary text-white text-base" > 保存分享海报到相册 </button> <button onClick={saveQrcode} className="btn btn-primary text-white text-base" > 只保存二维码到相册 </button> </div> <div id="print" className="flex flex-1 scale-90 flex-col bg-[#07050A] relative" > <div className="absolute top-0 left-0 w-full z-0"> <div className="relative w-full h-64 overflow-hidden"> <img src={ "/cors/" + data?.cover?.images[0].urls[0].split( "https://file.tiefen.fun/" )[1] } alt="" className="w-full object-cover 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 py-2 z-10 relative"> <div className="flex flex-col items-center mt-24"> <div className="w-[74px] h-[74px] rounded-full overflow-hidden"> <img src={ "/cors/" + data?.avatar?.images[0].urls[0].split( "https://file.tiefen.fun/" )[1] } 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> <div className="w-6 h-6"> <img src="/icon/verification.png" alt="" className="w-full" /> </div> </div> <p className="text-secondary text-sm text-center font-medium mt-3 px-4"> {data?.bio} </p> </div> <div className="flex flex-col mt-8 bg-[#FFFFFF1A] rounded-2xl"> <div className="flex flex-row cursor-pointer bg-[#07050A] border-2 border-[#FFFFFF26] rounded-2xl h-12 items-center justify-center"> <div className="w-5 h-5"> <img src="/images/platform_wechat.png" alt="" className="w-full object-cover" /> </div> <p className="text-white text-base font-medium ml-2">我的微信</p> </div> </div> {data?.platforms?.map((item, index) => ( <div key={index} className="flex flex-row cursor-pointer bg-[#07050A] border-2 border-[#FFFFFF26] rounded-2xl h-12 items-center justify-center mt-4" > <img src={ "/cors/" + item.icon.images[0].urls[0].split( "https://file.tiefen.fun/" )[1] } 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 justify-center pt-2 pb-4"> {qrcodeUrl && ( <Image className="aspect-square object-contain rounded-xl" src={qrcodeUrl} width={96} height={96} alt="" ></Image> )} </div> </div> </section> ); }