/* * Copyright © 2024 Hexastack. All rights reserved. * * Licensed under the GNU Affero General Public License v3.0 (AGPLv3) with the following additional terms: * 1. The name "Hexabot" is a trademark of Hexastack. You may not use this name in derivative works without express written permission. * 2. All derivative works must include clear attribution to the original creator and software, Hexastack and Hexabot, in a prominent location (e.g., in the software's "About" section, documentation, and README file). */ import React from "react"; import { useColors } from "../providers/ColorProvider"; import { IMenuNode } from "../types/menu.type"; import { IPayload } from "../types/message.types"; import "./MenuItem.scss"; interface MenuItemProps { item: IMenuNode; parent?: IMenuNode; onOpenSubItems: (item: IMenuNode) => void; onPostback: (data: IPayload) => void; } const MenuItem: React.FC = ({ item, parent, onOpenSubItems, onPostback, }) => { const { colors } = useColors(); const handleClick = () => { switch (item.type) { case "web_url": window.open(item.url, "_blank"); break; case "nested": onOpenSubItems({ ...item, _parent: parent }); break; case "postback": onPostback({ text: item.title, payload: item.payload }); break; } }; return (
{item.title} {item.type === "nested" && ( )}
); }; export default MenuItem;