import Image from "next/image"; import { observer } from "mobx-react-lite"; // hooks import { useApplication, useEventTracker, useProject, useProjectFilter } from "hooks/store"; // components import { EmptyState } from "components/empty-state"; import { ProjectCard } from "components/project"; import { ProjectsLoader } from "components/ui"; // assets import AllFiltersImage from "public/empty-state/project/all-filters.svg"; import NameFilterImage from "public/empty-state/project/name-filter.svg"; // constants import { EmptyStateType } from "constants/empty-state"; import { E_PROJECT_EMPTY_STATE } from "constants/event-tracker"; export const ProjectCardList = observer(() => { // store hooks const { commandPalette: commandPaletteStore } = useApplication(); const { setTrackElement } = useEventTracker(); const { workspaceProjectIds, filteredProjectIds, getProjectById } = useProject(); const { searchQuery } = useProjectFilter(); if (!filteredProjectIds) return ; if (workspaceProjectIds?.length === 0) return ( { setTrackElement(E_PROJECT_EMPTY_STATE); commandPaletteStore.toggleCreateProjectModal(true); }} /> ); if (filteredProjectIds.length === 0) return (
No matching projects
No matching projects

{searchQuery.trim() === "" ? "Remove the filters to see all projects" : "No projects detected with the matching\ncriteria. Create a new project instead"}

); return (
{filteredProjectIds.map((projectId) => { const projectDetails = getProjectById(projectId); if (!projectDetails) return; return ; })}
); });