mirror of
https://dev.azure.com/globalhealthx/EMR/_git/helix-engage
synced 2026-05-18 20:08:19 +00:00
feat: Contacts page + P360 for all tabs + dynamic column toggle + slot flicker fix
Contacts page:
- New /contacts route — shows leads with source=PHONE/WALK_IN/REFERRAL
- Leads page now excludes those sources (campaign-sourced only)
- Sidebar: Contacts nav item added for all roles; Leads added for cc-agent
- Same LeadTable + pagination + CSV export pattern as All Leads
P360 context panel for all worklist tabs (#6-10):
- WorklistPanel: onSelectLead → onSelectItem (generic WorklistSelection)
- call-desk: handleSelectItem builds ContextPanelSubject for any row type
- ContextPanelSubject type replaces (lead as any).patientId casts
- Highlight tracks row.id (mc-*/fu-*/lead-*) not lead.id
Dynamic column toggle (blank-screen fix):
- missed-calls + call-recordings refactored to React Aria dynamic
collections API (Table.Header columns={} + Table.Row columns={})
- Fixes "Cell count must match column count" crash on column hide
- Row-header column metadata in columnDefs instead of hardcoded JSX
Slot flickering fix (#2):
- Removed clinic + timeSlot from slot-fetch useEffect deps (circular
loop: effect sets clinic → clinic in deps → re-fires)
- Memoized timeSlotSelectItems
Other:
- GlobalSearch hidden (stale appointment state on navigation)
- Branch column: shows campaign name from relation, falls back to DID
- formatSource maps PHONE → "Phone"
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -5,6 +5,7 @@ import { useData } from '@/providers/data-provider';
|
||||
|
||||
type UseLeadsFilters = {
|
||||
source?: LeadSource;
|
||||
excludeSources?: Set<LeadSource>;
|
||||
status?: LeadStatus;
|
||||
search?: string;
|
||||
};
|
||||
@@ -17,7 +18,7 @@ type UseLeadsResult = {
|
||||
|
||||
export const useLeads = (filters: UseLeadsFilters = {}): UseLeadsResult => {
|
||||
const { leads, updateLead } = useData();
|
||||
const { source, status, search } = filters;
|
||||
const { source, excludeSources, status, search } = filters;
|
||||
|
||||
const filteredLeads = useMemo(() => {
|
||||
return leads.filter((lead) => {
|
||||
@@ -25,6 +26,10 @@ export const useLeads = (filters: UseLeadsFilters = {}): UseLeadsResult => {
|
||||
return false;
|
||||
}
|
||||
|
||||
if (excludeSources && lead.leadSource && excludeSources.has(lead.leadSource)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if (status !== undefined && lead.leadStatus !== status) {
|
||||
return false;
|
||||
}
|
||||
@@ -46,7 +51,7 @@ export const useLeads = (filters: UseLeadsFilters = {}): UseLeadsResult => {
|
||||
|
||||
return true;
|
||||
});
|
||||
}, [leads, source, status, search]);
|
||||
}, [leads, source, excludeSources, status, search]);
|
||||
|
||||
return {
|
||||
leads: filteredLeads,
|
||||
|
||||
Reference in New Issue
Block a user