- hasText now JOINs sender (LEFT JOIN) and uses EXISTS subqueries for receivers and tags to avoid duplicate rows - hasTagPartial added for live debounced tag text filter (ILIKE partial match) Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
- hasText now JOINs sender (LEFT JOIN) and uses EXISTS subqueries for receivers and tags to avoid duplicate rows - hasTagPartial added for live debounced tag text filter (ILIKE partial match) Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>