/* * 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). * 3. SaaS Restriction: This software, or any derivative of it, may not be used to offer a competing product or service (SaaS) without prior written consent from Hexastack. Offering the software as a service or using it in a commercial cloud environment without express permission is strictly prohibited. */ 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;