From 6ae43bdc1b790422ac7fc5429f929ac911a2b2d6 Mon Sep 17 00:00:00 2001 From: eleliauk <2831336720@qq.com> Date: Fri, 20 Dec 2024 00:39:47 +0800 Subject: [PATCH] =?UTF-8?q?feat(ansker):=20=E4=BF=AE=E6=94=B9=E5=9B=9E?= =?UTF-8?q?=E7=AD=94=E6=A0=B7=E5=BC=8F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../QuestionDetail/QuestionDetail.tsx | 67 ++++-- src/pages/evaluate/evaluate.tsx | 2 +- src/pages/questionInfo/index.scss | 22 ++ src/pages/questionInfo/index.tsx | 217 ++++++++---------- 4 files changed, 167 insertions(+), 141 deletions(-) diff --git a/src/common/components/QuestionDetail/QuestionDetail.tsx b/src/common/components/QuestionDetail/QuestionDetail.tsx index ca7ef28..75fc075 100644 --- a/src/common/components/QuestionDetail/QuestionDetail.tsx +++ b/src/common/components/QuestionDetail/QuestionDetail.tsx @@ -6,8 +6,9 @@ import answericon from '@/common/assets/img/publishQuestion/answer.png'; import askicon from '@/common/assets/img/publishQuestion/ask.png'; import IconFont from '@/common/components/iconfont'; import PublishHeader from '@/common/components/PublishHeader/PublishHeader'; -import { post } from '@/common/utils'; +import { get, post } from '@/common/utils'; import { useCourseStore } from '@/pages/main/store/store'; +import Taro from '@tarojs/taro'; interface IUser { avatar: string; @@ -76,7 +77,7 @@ const QuestionDetail: React.FC = ({ const dispatch = useCourseStore(({ getPublishers }) => ({ getPublishers })); const [questionDetail, setQuestion] = useState(question); - const [answersDetail, setAnswers] = useState(answers); + const [answersDetail, setAnswersDetail] = useState(answers); const [showAnswerForm, setShowAnswerForm] = useState(false); const [answerContent, setAnswerContent] = useState(''); @@ -102,10 +103,10 @@ const QuestionDetail: React.FC = ({ // 确保 answers 不为 null if (answers !== null) { const answersWithUserInfo = await getAnswersWithUserInfo(answers); - setAnswers(answersWithUserInfo); + setAnswersDetail(answersWithUserInfo); } else { // 如果 answers 为 null,可以选择设置一个空数组或者执行其他逻辑 - setAnswers([]); + setAnswersDetail([]); } // 函数,用于获取问题的提问者用户信息 @@ -129,6 +130,8 @@ const QuestionDetail: React.FC = ({ }, [question]); const handlePublishAnswer = async () => { + if (!answerContent.trim()) return; + try { // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment const response = await post('/answers/publish', { @@ -136,12 +139,47 @@ const QuestionDetail: React.FC = ({ question_id: question.id, }); - if (response) { + // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access + if (response?.code === 409002) { + void Taro.showToast({ + title: '不能回答未上过的课', + icon: 'none', + duration: 2000, + }); + return; + } + + // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access + if (response?.code === 0) { setAnswerContent(''); setShowAnswerForm(false); + + // 刷新回答列表 + try { + // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment + const res = await get( + `/answers/list/questions/${question.id}?cur_answer_id=${0}&limit=${100}` + ); + // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access + setAnswersDetail(res?.data as IAnswer[]); + + void Taro.showToast({ + title: '回答发布成功', + icon: 'success', + duration: 2000, + }); + } catch (error: unknown) { + const errorMessage = error instanceof Error ? error.message : 'Unknown error'; + console.error('获取回答列表失败:', errorMessage); + } } } catch (error) { console.error('发布回答失败:', error); + void Taro.showToast({ + title: '发布回答失败', + icon: 'error', + duration: 2000, + }); } }; @@ -163,15 +201,7 @@ const QuestionDetail: React.FC = ({ - - onAnswer?.(question.id)} - > - - - - + {answersDetail && answersDetail.map((answer, index) => ( = ({ ))} - - + {!showAnswerForm ? (