123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 |
- import { ScrollView, View,Image } from "@tarojs/components";
- import MessageRobotRich from "@/components/chat-message/MessageRobotRich";
- import MessageRich from "@/components/chat-message/MessageRich";
- import { WelcomeCard, AddSuccessfulTips } from "../asistant-message";
- import KnowledgeIcon from '@/components/KnowledgeIcon'
- import FigureList from "@/components/list/FigureList";
- import FigureListItem from "@/components/list/FigureListItem";
- import { useEffect, useRef, useState } from "react";
- import Taro, { useDidShow } from "@tarojs/taro";
- import { useUserStore } from "@/store/userStore";
- import { useKnowledgeStore } from "@/store/knowledge";
- import { TKnowledgeItem } from "@/types/knowledge";
- const ViewStyleChat = () => {
- const { list, scrollTop, loadMore } = useKnowledgeStore();
- const {whoami} = useUserStore();
- const avatarData = {
- avatar: ``,
- name: "小蓝本助手",
- };
-
- const onScrollToUpper = async () => {
- console.log("toUpper");
- loadMore();
- };
- const handleEdit = (item: TKnowledgeItem)=> {
- if(item.parseStatus !== 'parsed'){
- return ;
- }
- Taro.navigateTo({
- url: `/pages/knowledge-item/index?knowledgeId=${item.knowledgeId}`
- })
- }
- useDidShow(()=> {
- loadMore(true)
- })
- return (
- <ScrollView
- scrollY
- onScrollToUpper={onScrollToUpper}
- scrollTop={scrollTop}
- style={{
- flex: 1,
- height: "100%", // 高度自适应
- }}
- >
- <View className="flex flex-col gap-20 pb-80">
- {/* 欢迎语 */}
- <MessageRobotRich data={avatarData}>
- <WelcomeCard />
- </MessageRobotRich>
- {/* 添加小蓝本助手成功 */}
- {/* <MessageRobotRich data={avatarData}>
- <AddSuccessfulTips />
- </MessageRobotRich> */}
- {list.map((group) => {
- // 渲染自己发送的消息
- if (group.role === "user") {
- return group.knowledgeList.map((item) => {
- return (
- <MessageRich data={{
- avatar: whoami?.avatarUrl ?? '',
- name: whoami?.nickName ?? ''
- }}>
- <View className="flex items-center gap-12">
- <View className="w-36 h-36 overflow-hidden"><KnowledgeIcon data={item} /></View>
- <View className="flex flex-col flex-1 gap-2">
- <View className="text-14 leading-22">{item.title}</View>
- <View className="text-12 leading-20 text-gray-45">
- {item.createTime} | {item.fileSizeStr}
- </View>
- </View>
- </View>
- </MessageRich>
- );
- });
- }
- // 渲染机器人小蓝本助手的消息
- return (
- <MessageRobotRich
- data={{...avatarData, fileLen: group.knowledgeList.length}}
- analyzeStatus={group.isParsing ? "doing" : "done"}
- content={group.content}
- >
- <FigureList>
- {group.knowledgeList.map((item, index) => {
- return (
- <FigureListItem
- figure={()=> {
- return <KnowledgeIcon data={item}/>
- }}
- underline={index + 1 < group.knowledgeList.length}
- arrow={item.parseStatus === 'parsed'}
- onClick={()=> handleEdit(item)}
- >
- <View className="flex flex-col flex-1 gap-2 w-full">
- <View className="text-14 leading-22">{item.title}</View>
- <View className="text-12 leading-20 text-gray-45">
- {item.createTime} | {item.fileSizeStr}
- </View>
- </View>
- </FigureListItem>
- );
- })}
- </FigureList>
- </MessageRobotRich>
- );
- })}
- </View>
- </ScrollView>
- );
- };
- export default ViewStyleChat;
|