Skip to content

Commit

Permalink
fix: types and stuff
Browse files Browse the repository at this point in the history
  • Loading branch information
pl-buiquang committed Jan 15, 2025
1 parent 5bc8b0a commit 1fd9119
Show file tree
Hide file tree
Showing 28 changed files with 142 additions and 134 deletions.
96 changes: 46 additions & 50 deletions package-lock.json

Large diffs are not rendered by default.

1 change: 1 addition & 0 deletions src/__tests__/data/cohortCreation/conditionCriteria.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import {
form
} from 'components/CreationCohort/DiagramView/components/LogicalOperator/components/CriteriaRightPanel/forms/Cim10Form'
import { Comparators } from 'types/requestCriterias'
import { System } from 'types/scope'

export const defaultConditionCriteria: Cim10DataType = {
id: 1,
Expand Down
1 change: 1 addition & 0 deletions src/__tests__/data/cohortCreation/documentCriteria.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import {
form
} from 'components/CreationCohort/DiagramView/components/LogicalOperator/components/CriteriaRightPanel/forms/DocumentsForm'
import { Comparators } from 'types/requestCriterias'
import { System } from 'types/scope'
import { DocumentStatuses, SearchByTypes } from 'types/searchCriterias'

export const defaultDocumentCriteria: DocumentDataType = {
Expand Down
1 change: 1 addition & 0 deletions src/__tests__/data/cohortCreation/encounterCriteria.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import {
form
} from 'components/CreationCohort/DiagramView/components/LogicalOperator/components/CriteriaRightPanel/forms/EncounterForm'
import { Comparators } from 'types/requestCriterias'
import { System } from 'types/scope'

export const defaultEncounterCriteira: EncounterDataType = {
id: 1,
Expand Down
1 change: 1 addition & 0 deletions src/__tests__/data/cohortCreation/medicationCriteria.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import {
form
} from 'components/CreationCohort/DiagramView/components/LogicalOperator/components/CriteriaRightPanel/forms/MedicationForm'
import { Comparators, CriteriaType } from 'types/requestCriterias'
import { System } from 'types/scope'

export const defaultMedicationCriteria: MedicationDataType = {
id: 1,
Expand Down
3 changes: 3 additions & 0 deletions src/__tests__/data/cohortCreation/observationCriteria.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import {
form
} from 'components/CreationCohort/DiagramView/components/LogicalOperator/components/CriteriaRightPanel/forms/BiologyForm'
import { Comparators } from 'types/requestCriterias'
import { System } from 'types/scope'

export const defaultObservationCriteria: ObservationDataType = {
id: 1,
Expand All @@ -21,6 +22,8 @@ export const completeObservationCriteria: ObservationDataType = {
id: 'I3356',
label: 'I3356 - Erythrocytes Foetaux /érythrocytes Adultes_sang_cytochimie_hf/10000 Ha',
system: 'https://terminology.eds.aphp.fr/aphp-itm-anabio',
above_levels_ids: '*',
inferior_levels_ids: '',
isLeaf: true
}
],
Expand Down
1 change: 1 addition & 0 deletions src/__tests__/data/cohortCreation/procedureCriteria.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import {
form
} from 'components/CreationCohort/DiagramView/components/LogicalOperator/components/CriteriaRightPanel/forms/CCAMForm'
import { Comparators } from 'types/requestCriterias'
import { System } from 'types/scope'

export const defaultProcedureCriteria: CcamDataType = {
id: 1,
Expand Down
22 changes: 1 addition & 21 deletions src/components/CreationCohort/DataList_Criteria.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Back_API_Response, CriteriaItemType } from 'types'
import { CriteriaItemType } from 'types'

import RequestForm from './DiagramView/components/LogicalOperator/components/CriteriaRightPanel/RequestForm/RequestForm'

Expand All @@ -16,7 +16,6 @@ import { form as biologyForm } from './DiagramView/components/LogicalOperator/co
import { form as pregnantForm } from './DiagramView/components/LogicalOperator/components/CriteriaRightPanel/forms/PregnancyForm'
import { form as medicationForm } from './DiagramView/components/LogicalOperator/components/CriteriaRightPanel/forms/MedicationForm'
import { form as ippForm } from './DiagramView/components/LogicalOperator/components/CriteriaRightPanel/forms/IPPForm'
import { HIERARCHY_ROOT, getChildrenFromCodes, getCodeList } from 'services/aphp/serviceValueSets'

export enum CriteriaTypeLabels {
REQUEST = 'Mes requêtes',
Expand All @@ -38,25 +37,6 @@ export enum CriteriaTypeLabels {
HOSPIT = "Fiche d'hospitalisation"
}

import docTypes from 'assets/docTypes.json'
import { birthStatusData, booleanFieldsData, booleanOpenChoiceFieldsData, vmeData } from 'data/questionnaire_data'
import { VitalStatusLabel } from 'types/searchCriterias'
import { FhirItem } from 'types/valueSet'
import { createHierarchyRoot } from 'utils/hierarchy'

const async = (fetch: () => Promise<Back_API_Response<FhirItem>>) => async () => (await fetch()).results

const getCodesForValueSet = async (code: string, systems: string[]) => {
if (code === HIERARCHY_ROOT && systems.length) return [createHierarchyRoot(systems[0])]
for (const system of systems) {
try {
return (await getChildrenFromCodes(system, [code])).results
} catch {
console.error("Ce n'est pas une erreur.")
}
}
}

const criteriaList: () => CriteriaItemType[] = () => {
const ODD_QUESTIONNAIRE = getConfig().features.questionnaires.enabled
const ODD_BIOLOGY = getConfig().features.observation.enabled
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ import React, { useEffect, useState } from 'react'
import CriteriaLayout from 'components/ui/CriteriaLayout'
import {
CriteriaForm as CriteriaFormDefinition,
CriteriaFormItemViewProps,
NumberAndComparatorDataType,
NewDurationRangeType,
CommonCriteriaData,
Expand All @@ -11,7 +10,6 @@ import {
import { CFItem, CFSection } from './components'
import FORM_ITEM_RENDERER from './mappers/renderers'
import { useAppSelector } from 'state'
import { LabelObject } from 'types/searchCriterias'
import { isFunction, isString } from 'lodash'

export type CriteriaFormRuntimeProps<T> = {
Expand Down Expand Up @@ -65,8 +63,6 @@ export default function CriteriaForm<T extends CommonCriteriaData>(props: Criter
onDataChange?.(criteriaData)
}, [criteriaData, onDataChange])

console.log('rendering form')
console.log('test itemSections', itemSections)
return (
<CriteriaLayout
criteriaLabel={`${label}`}
Expand Down Expand Up @@ -99,8 +95,6 @@ export default function CriteriaForm<T extends CommonCriteriaData>(props: Criter
const duration = value as NewDurationRangeType
isNull = isNull || (duration.start === null && duration.end === null)
}
if (!isNull) console.log(isNull, item.valueKey, value)

return isNull
}
return true
Expand All @@ -114,7 +108,7 @@ export default function CriteriaForm<T extends CommonCriteriaData>(props: Criter
...item,
data: criteriaData,
getValueSetOptions: (valueSetId) => {
return (valueSets.entities[valueSetId]?.options || []) as LabelObject[]
return Object.values(valueSets.entities[valueSetId]?.options || {})
},
updateData: (newData: T) => {
setCriteriaData({ ...criteriaData, ...newData })
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -96,7 +96,8 @@ const unbuildEncounterServiceFilter = async (
existingValue?: Hierarchy<ScopeElement, string>[]
) => {
if (value) {
const encounterServices: ScopeElement[] = (await services.perimeters.getPerimeters({ ids: value })).results
const encounterServices: Hierarchy<ScopeElement>[] = (await services.perimeters.getPerimeters({ ids: value }))
.results
return encounterServices.concat(existingValue || [])
}
return Promise.resolve(existingValue || [])
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ import allDocTypes from 'assets/docTypes.json'
import moment from 'moment'
import { getDurationRangeLabel } from 'utils/age'
import { getConfig } from 'config'
import { FhirItem } from 'types/valueSet'

/************************************************************************************/
/* Criteria Form Item Chip Display */
Expand Down Expand Up @@ -138,7 +139,9 @@ const getLabelsForCodeSearchItem = (
return val
.map((value) => {
return (
(value.system ? valueSets.cache[value.system] : item.valueSetIds.flatMap((vid) => valueSets.cache[vid])) || []
(value.system
? valueSets.cache[value.system]
: item.valueSetsInfo.flatMap((valueset) => valueSets.cache[valueset.url])) || []
).find((code) => code && code.id === value.id) as LabelObject
})
.filter((code) => code !== undefined)
Expand All @@ -151,11 +154,14 @@ const getLabelsForAutoCompleteItem = (
): LabelObject[] => {
return val
.map((value) => {
return (item.valueSetData || Object.values(valueSets.entities[item.valueSetId]?.options || {}) || []).find(
(code) => code.id === value.id
)
return (
item.valueSetData ||
Object.values(valueSets.entities[item.valueSetId]?.options || {}).map((i) => i as LabelObject) ||
[]
).find((code) => code.id === value.id)
})
.filter((code) => code !== undefined)
.map((code) => code as LabelObject)
}

const chipFromAutoComplete = (
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -133,7 +133,7 @@ const DEFAULT_BUILD_METHOD: Record<CriteriaFormItemType, BuilderMethod> = {
select: BUILD_MAPPERS.buildSelect,
autocomplete: BUILD_MAPPERS.buildSelect,
number: BUILD_MAPPERS.buildSearch,
executiveUnit: BUILD_MAPPERS.buildLabelObject,
executiveUnit: BUILD_MAPPERS.buildEncounterService,
numberAndComparator: BUILD_MAPPERS.buildComparator,
boolean: BUILD_MAPPERS.buildSearch,
textWithCheck: BUILD_MAPPERS.buildSearch,
Expand Down Expand Up @@ -243,7 +243,7 @@ export const unbuildCriteriaDataFromDefinition = async <T extends SelectedCriter
const emptyCriterion: T = { ...criteriaDefinition.initialData } as T
emptyCriterion.id = element._id
emptyCriterion.type = criteriaDefinition.buildInfo.type[element.resourceType] as SelectedCriteriaType['type']
emptyCriterion.title = element.name
emptyCriterion.title = element.name ?? criteriaDefinition.title
emptyCriterion.isInclusive = element.isInclusive

if (element.occurrence && 'occurrence' in emptyCriterion) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ import { CriteriaLabel } from 'components/ui/CriteriaLabel'
import { Comparators } from 'types/requestCriterias'
import SimpleSelect from 'components/ui/Inputs/SimpleSelect'
import ValueSetField from 'components/SearchValueSet/ValueSetField'
import { HIERARCHY_ROOT } from 'services/aphp/serviceValueSets'

/************************************************************************************/
/* Criteria Form Item Renderer */
Expand Down Expand Up @@ -122,7 +123,7 @@ const FORM_ITEM_RENDERER: { [key in CriteriaFormItemType]: CriteriaFormItemView<
)
},
autocomplete: (props) => {
const arrayPropValue = isArray(props.value) ? props.value : [props.value]
const arrayPropValue = isArray(props.value) ? props.value : !!props.value ? [props.value] : []
const codeSystem = props.getValueSetOptions(props.definition.valueSetId)
const groupBy = props.definition.groupBy
const valueWithLabels = (arrayPropValue ?? []).map(
Expand Down Expand Up @@ -288,7 +289,19 @@ const FORM_ITEM_RENDERER: { [key in CriteriaFormItemType]: CriteriaFormItemView<
<ValueSetField
value={valueWithLabels}
references={props.definition.valueSetsInfo}
onSelect={(value) => props.updateData(value)}
onSelect={(value) => {
if (props.definition.checkIsLeaf) {
const valuesWithLeafInfo = value.map((v) => {
return {
...v,
isLeaf: !v.inferior_levels_ids && v.id !== HIERARCHY_ROOT
}
})
props.updateData(valuesWithLeafInfo)
} else {
props.updateData(value)
}
}}
placeholder={props.definition.label ?? 'Code(s) sélectionné(s)'}
/>
// <AsyncAutocomplete
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import { SourceType } from 'types/scope'
import { LabelObject } from 'types/searchCriterias'
import { CHIPS_DISPLAY_METHODS } from './mappers/chipDisplayMapper'
import { BUILD_MAPPERS, UNBUILD_MAPPERS } from './mappers/buildMappers'
import { Reference } from 'types/valueSet'
import { FhirItem, Reference } from 'types/valueSet'

/********************************************************************************/
/* Criteria Types */
Expand Down Expand Up @@ -124,8 +124,6 @@ export type CodeSearchItem = BaseCriteriaItem & {
type: 'codeSearch'
noOptionsText: string
checkIsLeaf?: boolean
/** Ids (urls) of valuesets that are allowed to be used for this code search */
valueSetIds: string[]
valueSetsInfo: Reference[]
}

Expand Down Expand Up @@ -180,6 +178,7 @@ export type DataTypes =
| string
| string[]
| LabelObject[]
| Hierarchy<FhirItem>[]
| number
| Hierarchy<ScopeElement, string>[]
| NumberAndComparatorDataType
Expand Down Expand Up @@ -207,7 +206,7 @@ export type DataTypeMapping = {
numberAndComparator: CriteriaTypeMapping<NumberWithComparatorCriteriaItem, NumberAndComparatorDataType>
boolean: CriteriaTypeMapping<BooleanCriteriaItem, boolean>
textWithCheck: CriteriaTypeMapping<TextWithCheckItem, string>
codeSearch: CriteriaTypeMapping<CodeSearchItem, LabelObject[]>
codeSearch: CriteriaTypeMapping<CodeSearchItem, Hierarchy<FhirItem>[]>
textWithRegex: CriteriaTypeMapping<TextWithRegexCriteriaItem, string>
radioChoice: CriteriaTypeMapping<RadioChoiceCriteriaItem, string>
info: CriteriaTypeMapping<InfoCriteriaItem, string>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,17 +7,19 @@ import {
WithEncounterStatusDataType,
WithOccurenceCriteriaDataType
} from '../CriteriaForm/types'
import { LabelObject } from 'types/searchCriterias'
import { SourceType } from 'types/scope'
import { getConfig } from 'config'
import { BiologyStatus } from 'types'
import { getValueSetsFromSystems } from 'utils/valueSets'
import { FhirItem } from 'types/valueSet'
import { Hierarchy } from 'types/hierarchy'

export type ObservationDataType = CommonCriteriaData &
WithOccurenceCriteriaDataType &
WithEncounterDateDataType &
WithEncounterStatusDataType & {
type: CriteriaType.OBSERVATION
code: LabelObject[] | null
code: Hierarchy<FhirItem & { isLeaf?: boolean }>[] | null
searchByValue: NumberAndComparatorDataType | null
enableSearchByValue: boolean
}
Expand Down Expand Up @@ -66,13 +68,13 @@ export const form: () => CriteriaForm<ObservationDataType> = () => ({
type: 'codeSearch',
label: 'Codes de biologie',
checkIsLeaf: true,
valueSetIds: [
valueSetsInfo: getValueSetsFromSystems([
getConfig().features.observation.valueSets.biologyHierarchyAnabio.url,
getConfig().features.observation.valueSets.biologyHierarchyLoinc.url
],
]),
noOptionsText: 'Veuillez entrer un code de biologie',
buildInfo: {
fhirKey: ObservationParamsKeys.ANABIO_LOINC,
fhirKey: ObservationParamsKeys.CODE,
buildMethodExtraArgs: [
{ type: 'string', value: getConfig().features.observation.valueSets.biologyHierarchyAnabio.url },
{ type: 'boolean', value: true }
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,16 +6,18 @@ import {
WithEncounterStatusDataType,
WithOccurenceCriteriaDataType
} from '../CriteriaForm/types'
import { LabelObject } from 'types/searchCriterias'
import { SourceType } from 'types/scope'
import { getConfig } from 'config'
import { getValueSetsFromSystems } from 'utils/valueSets'
import { Hierarchy } from 'types/hierarchy'
import { FhirItem } from 'types/valueSet'

export type CcamDataType = CommonCriteriaData &
WithOccurenceCriteriaDataType &
WithEncounterDateDataType &
WithEncounterStatusDataType & {
type: CriteriaType.PROCEDURE
code: LabelObject[] | null
code: Hierarchy<FhirItem>[] | null
source: string | null
}

Expand Down Expand Up @@ -86,7 +88,7 @@ export const form: () => CriteriaForm<CcamDataType> = () => ({
valueKey: 'code',
type: 'codeSearch',
label: "Codes d'actes CCAM",
valueSetIds: [getConfig().features.procedure.valueSets.procedureHierarchy.url],
valueSetsInfo: getValueSetsFromSystems([getConfig().features.procedure.valueSets.procedureHierarchy.url]),
noOptionsText: 'Veuillez entrer un code ou un acte CCAM',
buildInfo: {
fhirKey: ProcedureParamsKeys.CODE,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,16 +6,18 @@ import {
WithEncounterStatusDataType,
WithOccurenceCriteriaDataType
} from '../CriteriaForm/types'
import { LabelObject } from 'types/searchCriterias'
import { SourceType } from 'types/scope'
import { getConfig } from 'config'
import { getValueSetsFromSystems } from 'utils/valueSets'
import { FhirItem } from 'types/valueSet'
import { Hierarchy } from 'types/hierarchy'

export type Cim10DataType = CommonCriteriaData &
WithOccurenceCriteriaDataType &
WithEncounterDateDataType &
WithEncounterStatusDataType & {
type: CriteriaType.CONDITION
code: LabelObject[] | null
code: Hierarchy<FhirItem>[] | null
source: string | null
diagnosticType: string[] | null
}
Expand Down Expand Up @@ -87,7 +89,7 @@ export const form: () => CriteriaForm<Cim10DataType> = () => ({
{
valueKey: 'code',
type: 'codeSearch',
valueSetIds: [getConfig().features.condition.valueSets.conditionHierarchy.url],
valueSetsInfo: getValueSetsFromSystems([getConfig().features.condition.valueSets.conditionHierarchy.url]),
noOptionsText: 'Veuillez entrer un code ou un diagnostic CIM10',
label: 'Code CIM10',
buildInfo: {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -98,11 +98,6 @@ export const form: () => CriteriaForm<DemographicDataType> = () => ({
},
disableCondition: (data) => {
const typedData = data as DemographicDataType
console.log(
'disabled',
typedData.birthdates !== null &&
(typedData.birthdates.start !== null || typedData.birthdates.end !== null)
)
return (
typedData.birthdates !== null &&
(typedData.birthdates.start !== null || typedData.birthdates.end !== null)
Expand Down
Loading

0 comments on commit 1fd9119

Please sign in to comment.