import React from 'react'; import { Avatar, Button, Input, Menu, MenuProps, Progress, Typography, Tooltip } from 'antd'; import { useStore } from '@/mstore'; import Project from '@/mstore/types/project'; import { observer } from 'mobx-react-lite'; import { AppWindowMac, EditIcon, Smartphone, } from 'lucide-react'; import { PlusOutlined, SearchOutlined, EditOutlined } from '@ant-design/icons' import ProjectForm from 'Components/Client/Projects/ProjectForm'; import { useModal } from 'Components/ModalContext'; type MenuItem = Required['items'][number]; const ProjectList: React.FC = () => { const { projectsStore } = useStore(); const [search, setSearch] = React.useState(''); const { openModal, closeModal } = useModal(); const filteredProjects = projectsStore.list.filter((project: Project) => project.name.toLowerCase().includes(search.toLowerCase()) ); const handleSearch = (value: string) => setSearch(value); const onClick: MenuProps['onClick'] = (e) => { const pid = parseInt(e.key as string); projectsStore.setConfigProject(pid); }; const projectEditHandler = (e: React.MouseEvent, project: Project) => { // e.stopPropagation(); projectsStore.initProject(project); openModal(, { title: 'Edit Project' }); }; const menuItems: MenuItem[] = filteredProjects.map((project) => ({ key: project.id + '', label: {project.name}, extra: } onChange={(e) => setSearch(e.target.value)} allowClear className='rounded-lg' />
); }; export default observer(ProjectList); const ProjectIconWithProgress: React.FC<{ platform: string; progress: number; }> = ({ platform, progress }) => (
''} strokeWidth={4} strokeColor="#23959a" />
) : ( ) } />
);