Skip to main content
Glama
SearchPage.tsx4.37 kB
// SPDX-FileCopyrightText: Copyright Orangebot, Inc. and Medplum contributors // SPDX-License-Identifier: Apache-2.0 import { Paper } from '@mantine/core'; import { formatSearchQuery, parseSearchRequest } from '@medplum/core'; import type { Filter, SearchRequest, SortRule } from '@medplum/core'; import type { UserConfiguration } from '@medplum/fhirtypes'; import { Loading, SearchControl, useMedplum } from '@medplum/react'; import { useEffect, useState } from 'react'; import type { JSX } from 'react'; import { useLocation, useNavigate } from 'react-router'; import classes from './SearchPage.module.css'; export function SearchPage(): JSX.Element { const medplum = useMedplum(); const navigate = useNavigate(); const location = useLocation(); const [search, setSearch] = useState<SearchRequest>(); useEffect(() => { const parsedSearch = parseSearchRequest(location.pathname + location.search); if (!parsedSearch.resourceType) { // If there is no search, go to the Patient search page by default navigate('/Patient')?.catch(console.error); return; } // Populate the search with default values as necessary const populatedSearch = addSearchValues(parsedSearch, medplum.getUserConfiguration()); if ( // If the current url matches the search, set the search, otherwise navigate to the correct url location.pathname === `/${populatedSearch.resourceType}` && location.search === formatSearchQuery(populatedSearch) ) { saveLastSearch(populatedSearch); setSearch(populatedSearch); } else { navigate(`/${populatedSearch.resourceType}${formatSearchQuery(populatedSearch)}`)?.catch(console.error); } }, [medplum, navigate, location]); if (!search?.resourceType || !search.fields || search.fields.length === 0) { return <Loading />; } return ( <Paper shadow="xs" m="md" p="xs" className={classes.paper}> <SearchControl checkboxesEnabled={false} search={search} onClick={(e) => navigate(`/${e.resource.resourceType}/${e.resource.id}`)?.catch(console.error)} onAuxClick={(e) => window.open(`/${e.resource.resourceType}/${e.resource.id}`, '_blank')} onChange={(e) => { navigate(`/${search.resourceType}${formatSearchQuery(e.definition)}`)?.catch(console.error); }} hideFilters={true} hideToolbar /> </Paper> ); } function addSearchValues(search: SearchRequest, config: UserConfiguration | undefined): SearchRequest { const resourceType = search.resourceType || getDefaultResourceType(config); const fields = search.fields ?? getDefaultFields(search.resourceType); const filters = search.filters ?? (!search.resourceType ? getDefaultFilters(resourceType) : undefined); const sortRules = search.sortRules ?? getDefaultSortRules(resourceType); return { ...search, resourceType, fields, filters, sortRules, }; } function getDefaultResourceType(config: UserConfiguration | undefined): string { return ( localStorage.getItem('defaultResourceType') ?? config?.option?.find((o) => o.id === 'defaultResourceType')?.valueString ?? 'Task' ); } function getDefaultFilters(resourceType: string): Filter[] | undefined { return getLastSearch(resourceType)?.filters; } function getDefaultSortRules(resourceType: string): SortRule[] { const lastSearch = getLastSearch(resourceType); if (lastSearch?.sortRules) { return lastSearch.sortRules; } return [{ code: '_lastUpdated', descending: true }]; } function getLastSearch(resourceType: string): SearchRequest | undefined { const value = localStorage.getItem(resourceType + '-defaultSearch'); return value ? (JSON.parse(value) as SearchRequest) : undefined; } function saveLastSearch(search: SearchRequest): void { localStorage.setItem('defaultResourceType', search.resourceType); localStorage.setItem(search.resourceType + '-defaultSearch', JSON.stringify(search)); } function getDefaultFields(resourceType: string): string[] { switch (resourceType) { case 'Patient': return ['name', 'gender', 'birthDate', '_lastUpdated']; case 'Practitioner': return ['name', '_lastUpdated']; case 'QuestionnaireResponse': return ['_id', 'questionnaire', 'author', '_lastUpdated']; default: return ['_id', '_lastUpdated']; } }

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/medplum/medplum'

If you have feedback or need assistance with the MCP directory API, please join our Discord server