From 2c0378c63abd4d0e162d2c97923049ca85dde957 Mon Sep 17 00:00:00 2001 From: laxmanhalaki Date: Mon, 8 Dec 2025 12:46:33 +0530 Subject: [PATCH] @ added in share summary --- src/components/modals/ShareSummaryModal.tsx | 29 +++++++++++++++++---- 1 file changed, 24 insertions(+), 5 deletions(-) diff --git a/src/components/modals/ShareSummaryModal.tsx b/src/components/modals/ShareSummaryModal.tsx index 0c838fc..eb1e419 100644 --- a/src/components/modals/ShareSummaryModal.tsx +++ b/src/components/modals/ShareSummaryModal.tsx @@ -24,17 +24,25 @@ export function ShareSummaryModal({ isOpen, onClose, summaryId, requestTitle, on const [searching, setSearching] = useState(false); const [sharing, setSharing] = useState(false); - // Search users + // Search users - only when input starts with @ useEffect(() => { - if (!isOpen || !searchTerm.trim()) { + if (!isOpen) { setUsers([]); return; } + // Only trigger search when using @ sign + if (!searchTerm || !searchTerm.startsWith('@') || searchTerm.length < 2) { + setUsers([]); + setSearching(false); + return; + } + const searchTimeout = setTimeout(async () => { try { setSearching(true); - const response = await searchUsers(searchTerm); + const term = searchTerm.slice(1); // Remove @ prefix + const response = await searchUsers(term, 10); const results = response?.data?.data || response?.data || []; setUsers(Array.isArray(results) ? results : []); } catch (error) { @@ -111,12 +119,17 @@ export function ShareSummaryModal({ isOpen, onClose, summaryId, requestTitle, on setSearchTerm(e.target.value)} className="pl-10" /> + {searchTerm && !searchTerm.startsWith('@') && ( +

+ Start with @ to search users (e.g., @john) +

+ )} {searching && ( @@ -163,11 +176,17 @@ export function ShareSummaryModal({ isOpen, onClose, summaryId, requestTitle, on )} - {!searching && searchTerm && users.length === 0 && ( + {!searching && searchTerm && searchTerm.startsWith('@') && users.length === 0 && (
No users found
)} + + {!searching && searchTerm && !searchTerm.startsWith('@') && ( +
+ Start typing with @ to search users +
+ )} {selectedUserIds.size > 0 && (