From 539be2b06ae249c0cce76f2c0664605424dc445d Mon Sep 17 00:00:00 2001 From: al <al@cdhncy.com> Date: Mon, 22 Jul 2024 17:55:52 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E5=AE=A2=E6=9C=8Dbug?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/globals.css | 4 +- .../{index.module.css => index.module.scss} | 24 ++--- app/login/page.js | 6 +- app/messageDetail/page.js | 96 +++++++++++-------- app/my/setting/deleteAccount/page.js | 3 +- components/WithAuth/index.js | 17 ++-- 6 files changed, 86 insertions(+), 64 deletions(-) rename app/login/{index.module.css => index.module.scss} (80%) diff --git a/app/globals.css b/app/globals.css index 9112745..e5958fe 100644 --- a/app/globals.css +++ b/app/globals.css @@ -92,7 +92,7 @@ body{ .tabPinkLine::after { content: ""; position: absolute; - background-image: url(http://localhost:3000/icons/tabindicator.png); + background-image: url("/icons/tabindicator.png"); height: 34px; background-position: -2px -18px; background-size: cover; @@ -105,7 +105,7 @@ body{ .titlePinkLine::after { content: ""; position: absolute; - background-image: url(http://localhost:3000/icons/pinkline.png); + background-image: url("/icons/pinkline.png"); height: 12px; width: inherit; min-width: 42px; diff --git a/app/login/index.module.css b/app/login/index.module.scss similarity index 80% rename from app/login/index.module.css rename to app/login/index.module.scss index d89143b..76c07d0 100644 --- a/app/login/index.module.css +++ b/app/login/index.module.scss @@ -1,11 +1,21 @@ + +.customTabs { + border: none; + --active-line-color: #ff8383; + --active-title-color: #fff; + --title-color: #a0a0a0; + --inactive-title-color: #FFFFFF80; + --tab-border-color: #ff8383; +} + .customTabs>div>div:last-child>div:first-child { z-index: 1; background: none; } -.customTabs>div>div:last-child>div:first-child ::after{ - content: ''; - background-image: url(http://localhost:3000/icons/tabindicator.png); +.customTabs>div>div:last-child>div:first-child::after{ + content: ""; + background-image: url("/icons/tabindicator.png"); height: 44px; background-size: cover; background-repeat: no-repeat; @@ -14,14 +24,6 @@ top: -48px; left: calc(50% - 25px); } -.customTabs { - border: none; - --active-line-color: #ff8383; - --active-title-color: #fff; - --title-color: #a0a0a0; - --inactive-title-color: #5c5c5c; - --tab-border-color: #ff8383; -} /* .loginBox .adm-tabs .adm-tabs-tab { color: #a0a0a0; } */ diff --git a/app/login/page.js b/app/login/page.js index d4780a3..23e60cd 100644 --- a/app/login/page.js +++ b/app/login/page.js @@ -12,7 +12,7 @@ import { Image, } from "antd-mobile"; import { useRouter } from "next/navigation"; -import styles from "./index.module.css"; +import styles from "./index.module.scss"; import { JSEncrypt } from "jsencrypt"; import { handleLogin } from "@/store/actions"; import { saveUserInfo, removeUserInfo } from "@/utils/storeInfo"; @@ -197,13 +197,13 @@ function Login({ handleLogin }) { } }; return ( - <div className={`${styles.loginBox} flex flex-col justify-center items-center`}> + <div className={`${styles.loginBox}`}> <Image src={process.env.NEXT_PUBLIC_CDN_URL + "/public/images/slogan.png"} alt="" className="mt-24 w-[90vw]" /> - <div className="mt-6 flex justify-between items-center px-2 text-gray-400 sticky top-0 z-10 bg-deepBg"> + <div className="mt-6 flex justify-between items-center px-2 text-[#ffffff80] sticky top-0 z-10 bg-deepBg"> <Tabs activeKey={tabItems[activeIndex].key} onChange={(key) => { diff --git a/app/messageDetail/page.js b/app/messageDetail/page.js index d9e70ad..fd7a858 100644 --- a/app/messageDetail/page.js +++ b/app/messageDetail/page.js @@ -42,7 +42,6 @@ export default function MessageDetail({}) { if (oldMessages[0]) { updateMessages(oldMessages[0]?.id, 0, oldMessages); // toScrollBottom.current = 1; - } }, 3000); // 间隔时间为3秒 @@ -53,8 +52,7 @@ export default function MessageDetail({}) { }, [oldMessages]); useEffect(() => { if (toScrollBottom.current) { - - scrollBox.current?.scrollTo(0, scrollBox.current.scrollHeight+50); + scrollBox.current?.scrollTo(0, scrollBox.current.scrollHeight + 50); toScrollBottom.current = 0; } }, [messages]); @@ -79,14 +77,17 @@ export default function MessageDetail({}) { }, [sessionId]); //查询session const getSession = async (mid) => { - setLoading(true) + setLoading(true); try { - const data = - await requireAPI("POST", "/api/contact_customer_service_session/list_by_mid", { + const data = await requireAPI( + "POST", + "/api/contact_customer_service_session/list_by_mid", + { body: { mid: Number(mid), }, - }); + } + ); if (data.ret === -1) { Toast.show({ icon: "fail", @@ -94,26 +95,32 @@ export default function MessageDetail({}) { position: "top", }); } - setLoading(false) + setLoading(false); if (data.data.session) { setSessionId(data.data.session.id); - return; + } else { + //如果是第一次发送,需要创建session + createSession(mid); } } catch (error) { console.error(error); } }; //创建session - const createSession = async () => { - setLoading(true) + const createSession = async (mid) => { + setLoading(true); try { - const data = - await requireAPI("POST", "/api/contact_customer_service_session/create", { + const data = await requireAPI( + "POST", + "/api/contact_customer_service_session/create", + { body: { sub_mid: Number(mid), obj_mid: 0, }, - }); + } + ); + if (data.ret === -1) { Toast.show({ icon: "fail", @@ -122,7 +129,7 @@ export default function MessageDetail({}) { }); } setSessionId(data.data.session_id); - setLoading(false) + setLoading(false); } catch (error) { console.error(error); } @@ -131,15 +138,18 @@ export default function MessageDetail({}) { const loadEarlierHistory = async () => { if (!more) return; try { - setLoading(true) - const data = - await requireAPI("POST", "/api/contact_customer_service/list_by_session_id", { + setLoading(true); + const data = await requireAPI( + "POST", + "/api/contact_customer_service/list_by_session_id", + { body: { session_id: sessionId, offset: offset, limit: 12, }, - }); + } + ); if (data.ret === -1) { Toast.show({ icon: "fail", @@ -150,9 +160,9 @@ export default function MessageDetail({}) { } setOffset(data.data.offset); setMore(data.data.more); - let mathNewMessages = handleData([...oldMessages,...data.data.list]); + let mathNewMessages = handleData([...oldMessages, ...data.data.list]); // setMessages((prev) => [...prev, ...temMessages]); - setLoading(false) + setLoading(false); return mathNewMessages; } catch (error) { console.error(error); @@ -170,21 +180,21 @@ export default function MessageDetail({}) { return; } - //如果是第一次发送,需要创建session - if (!sessionId) await createSession(); - //查询历史记录的时候后移一位,防止记录重复 setOffset((prev) => prev + 1); //请求接口发送私信 try { - const data = - await requireAPI("POST", "/api/contact_customer_service/create", { + const data = await requireAPI( + "POST", + "/api/contact_customer_service/create", + { body: { session_id: sessionId, predicate: 0, message, }, - }); + } + ); if (data.ret === -1) { Toast.show({ icon: "error", @@ -195,7 +205,7 @@ export default function MessageDetail({}) { } // updateLatestHistory(); // console.log("oldArr", oldArr); - updateMessages(lastId, 0, oldArr).then(res=>{ + updateMessages(lastId, 0, oldArr).then((res) => { setNewMessage(""); toScrollBottom.current = 1; }); @@ -310,14 +320,17 @@ export default function MessageDetail({}) { const updateMessages = async (lastId, currentOffset, oldArr) => { // console.log("lastId", lastId); try { - const data = - await requireAPI("POST", "/api/contact_customer_service/list_by_session_id", { + const data = await requireAPI( + "POST", + "/api/contact_customer_service/list_by_session_id", + { body: { session_id: sessionId, offset: currentOffset, limit: 12, }, - }); + } + ); if (data.ret === -1) { Toast.show({ icon: "fail", @@ -330,12 +343,12 @@ export default function MessageDetail({}) { return element.id > lastId; }); // console.log("[...messages,...newData]", [...newData]); - let mathNewMessages = handleData([...newData,...oldArr]); + let mathNewMessages = handleData([...newData, ...oldArr]); setMessages((old) => { toScrollBottom.current = 1; return mathNewMessages; }); - return + return; } catch (error) { console.error(error); } @@ -357,11 +370,14 @@ export default function MessageDetail({}) { <div> <div className="my-[57px]"> <div className="flex justify-center py-2"> - <div - className="px-3 py-2 rounded-full bg-[#FFFFFF1A]" - - > - {loading? <DotLoading /> : more ? <span onClick={loadMore}>查看更早</span>:<span>无更早消息</span>} + <div className="px-3 py-2 rounded-full bg-[#FFFFFF1A]"> + {loading ? ( + <DotLoading /> + ) : more ? ( + <span onClick={loadMore}>查看更早</span> + ) : ( + <span>无更早消息</span> + )} </div> </div> <ul className="py-2"> @@ -429,7 +445,9 @@ export default function MessageDetail({}) { <Button size="middle" block - onClick={() => onSend(newMessage, oldMessages[0].id, oldMessages)} + onClick={() => + onSend(newMessage, oldMessages[0]?.id || -1, oldMessages) + } style={{ "--background-color": "#FF669E", color: "#FFFFFF" }} > 发送 diff --git a/app/my/setting/deleteAccount/page.js b/app/my/setting/deleteAccount/page.js index b4df6b4..dd5e08b 100644 --- a/app/my/setting/deleteAccount/page.js +++ b/app/my/setting/deleteAccount/page.js @@ -1,7 +1,7 @@ "use client"; import React, { useState, useEffect, useRef } from "react"; -import { Button,Dialog } from "antd-mobile"; +import { Button,Dialog,Toast } from "antd-mobile"; import { FontAwesomeIcon } from "@fortawesome/react-fontawesome"; import { faAngleLeft, @@ -37,6 +37,7 @@ export default function DeleteAccount() { const handleDeleteAccount = async () => { try { const _data = await requireAPI("POST", "/api/account/cancel"); + console.log("requireAPI",_data) if (_data.ret === -1) { Toast.show({ icon: "fail", diff --git a/components/WithAuth/index.js b/components/WithAuth/index.js index 92dd3f3..b00d0e5 100644 --- a/components/WithAuth/index.js +++ b/components/WithAuth/index.js @@ -8,9 +8,11 @@ export default function WithAuth(WrappedComponent) { const pathname = usePathname(); useEffect(() => { - if(!pathname.includes("webView") && !pathname.includes("login") ) - checkLogin(); - console.log("isLogin",!pathname.includes("webView") && !pathname.includes("login")) + if(!pathname.includes("webView") && !pathname.includes("login") ){ + checkLogin(); + } + + // console.log("isLogin",!pathname.includes("webView") && !pathname.includes("login")) }, [pathname]); const checkLogin = async () => { const hasToken = await get("token"); @@ -27,14 +29,13 @@ export default function WithAuth(WrappedComponent) { position: "top", }); router.push("/login"); + }else{ + if(pathname.includes("login")){ + router.replace("/") + } } } } else { - Toast.show({ - icon: "fail", - content:"当前登录失效,请重新登录", - position: "top", - }); router.push("/login"); } };