// Copyright 2023 The Casdoor Authors. All Rights Reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. import React from "react"; import {Button, Menu} from "antd"; import {DeleteOutlined, LayoutOutlined, PlusOutlined} from "@ant-design/icons"; class ChatMenu extends React.Component { constructor(props) { super(props); const items = this.chatsToItems(this.props.chats); const openKeys = items.map((item) => item.key); this.state = { openKeys: openKeys, selectedKeys: ["0-0"], }; } chatsToItems(chats) { const categories = {}; chats.forEach((chat) => { if (!categories[chat.category]) { categories[chat.category] = []; } categories[chat.category].push(chat); }); const selectedKeys = this.state === undefined ? [] : this.state.selectedKeys; return Object.keys(categories).map((category, index) => { return { key: `${index}`, icon: , label: category, children: categories[category].map((chat, chatIndex) => { const globalChatIndex = chats.indexOf(chat); const isSelected = selectedKeys.includes(`${index}-${chatIndex}`); return { key: `${index}-${chatIndex}`, index: globalChatIndex, label: (
{chat.displayName} {isSelected && ( { e.currentTarget.style.color = "rgba(89,54,213,0.6)"; }} onMouseLeave={(e) => { e.currentTarget.style.color = "inherit"; }} onMouseDown={(e) => { e.currentTarget.style.color = "rgba(89,54,213,0.4)"; }} onMouseUp={(e) => { e.currentTarget.style.color = "rgba(89,54,213,0.6)"; }} onClick={(e) => { e.stopPropagation(); if (this.props.onDeleteChat) { this.props.onDeleteChat(globalChatIndex); } }} /> )}
), }; }), }; }); } onSelect = (info) => { const [categoryIndex, chatIndex] = info.selectedKeys[0].split("-").map(Number); const selectedItem = this.chatsToItems(this.props.chats)[categoryIndex].children[chatIndex]; this.setState({selectedKeys: [`${categoryIndex}-${chatIndex}`]}); if (this.props.onSelectChat) { this.props.onSelectChat(selectedItem.index); } }; getRootSubmenuKeys(items) { return items.map((item, index) => `${index}`); } onOpenChange = (keys) => { const items = this.chatsToItems(this.props.chats); const rootSubmenuKeys = this.getRootSubmenuKeys(items); const latestOpenKey = keys.find((key) => this.state.openKeys.indexOf(key) === -1); if (rootSubmenuKeys.indexOf(latestOpenKey) === -1) { this.setState({openKeys: keys}); } else { this.setState({openKeys: latestOpenKey ? [latestOpenKey] : []}); } }; render() { const items = this.chatsToItems(this.props.chats); return ( <> ); } } export default ChatMenu;