import { LinkIcon, MilestoneIcon } from "lucide-react"; import { memo, useState } from "react"; import { Link } from "react-router-dom"; import { MemoRelation } from "@/types/proto/api/v1/memo_relation_service"; import { Memo } from "@/types/proto/api/v1/memo_service"; import { cn } from "@/utils"; interface Props { memo: Memo; relations: MemoRelation[]; parentPage?: string; } const MemoRelationListView = (props: Props) => { const { memo, relations: relationList, parentPage } = props; const referencingMemoList = relationList .filter((relation) => relation.memo?.name === memo.name && relation.relatedMemo?.name !== memo.name) .map((relation) => relation.relatedMemo!); const referencedMemoList = relationList .filter((relation) => relation.memo?.name !== memo.name && relation.relatedMemo?.name === memo.name) .map((relation) => relation.memo!); const [selectedTab, setSelectedTab] = useState<"referencing" | "referenced">( referencingMemoList.length === 0 ? "referenced" : "referencing", ); if (referencingMemoList.length + referencedMemoList.length === 0) { return null; } return (
{referencingMemoList.length > 0 && ( )} {referencedMemoList.length > 0 && ( )}
{selectedTab === "referencing" && referencingMemoList.length > 0 && (
{referencingMemoList.map((memo) => { return ( {memo.uid.slice(0, 6)} {memo.snippet} ); })}
)} {selectedTab === "referenced" && referencedMemoList.length > 0 && (
{referencedMemoList.map((memo) => { return ( {memo.uid.slice(0, 6)} {memo.snippet} ); })}
)}
); }; export default memo(MemoRelationListView);