"use client"; import React, { useState, useEffect } from "react"; import QRCode from "qrcode"; import { Toast } from "antd-mobile"; import { useRouter, useParams } from "next/navigation"; import requireAPI from "@/utils/requireAPI"; import { FontAwesomeIcon } from "@fortawesome/react-fontawesome"; import { faAngleLeft } from "@fortawesome/free-solid-svg-icons"; import { saveDivImage } from "@/utils/tools/handleFuns"; import clipboard from "copy-to-clipboard"; export default function Share() { //获取页面数据、生成二维码 const [data, setData] = useState({}); const [qrcodeUrl, setQrcodeUrl] = useState(""); const [shareWebUrl, setShareWebUrl] = useState("https://tiefen.fun"); const [isFetching, setIsFetching] = useState(true); const router = useRouter(); const { user_id } = useParams(); function generateRandomString(length = 10) { const characters = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"; let result = ""; for (let i = 0; i < length; i++) { result += characters.charAt( Math.floor(Math.random() * characters.length) ); } return result; } useEffect(() => { function getRandomUrl(urls) { return urls[Math.floor(Math.random() * urls.length)]; } const getShareWebUrl = async () => { try { const data = await requireAPI("POST", "/api/config/cold_config", { body: {}, }); if (data.ret === -1) { Toast.show({ content: data.msg, }); return "https://tiefen.fun"; } const randomUrl = getRandomUrl(data.data.share_redirect_urls); return randomUrl; } catch (error) { return "https://tiefen.fun"; } }; const getData = async () => { try { const data = await requireAPI( "POST", "/api/streamer/list_ext_by_user_id", { body: { user_id: parseInt(user_id, 10) }, } ); if (data.ret === -1) { Toast.show({ content: data.msg, }); return; } setData(data.data.streamer_ext); const _shareWebUrl = await getShareWebUrl(); setShareWebUrl(_shareWebUrl); const randomStr = generateRandomString(); QRCode.toDataURL( `${_shareWebUrl}/zone/${user_id}/${randomStr}`, function (err, url) { setQrcodeUrl(url); } ); setIsFetching(false); } catch (error) { console.error(error); } }; getData(); getShareWebUrl(); }, []); //分享海报组件 const Poster = () => { return (
{data?.name}
ID
{data?.user_id}
邀您加入我的 「铁粉空间」