Condition

Introduction #

The Condition model represents a clinical condition, problem, diagnosis, or other event, situation, issue, or clinical concept that has risen to a level of concern.

Basic usage #

To get a condition by identifier, use the get method on the Condition model manager:

from canvas_sdk.v1.data.condition import Condition

condition = Condition.objects.get(id="b80b1cdc-2e6a-4aca-90cc-ebc02e683f35")

If you have a patient object, the conditions for a patient can be accessed with the conditions attribute on a Patient object:

from canvas_sdk.v1.data.patient import Patient

patient = Patient.objects.get(id="1eed3ea2a8d546a1b681a2a45de1d790")
conditions = patient.conditions.all()

If you have a patient ID, you can get the conditions for the patient with the for_patient method on the Condition model manager:

from canvas_sdk.v1.data.condition import Condition

patient_id = "1eed3ea2a8d546a1b681a2a45de1d790"
condition = Condition.objects.for_patient(patient_id)

Codings #

The codings for a condition can be accessed with the codings attribute on an Condition object:

from canvas_sdk.v1.data.condition import Condition
from logger import log

condition = Condition.objects.get(id="b80b1cdc-2e6a-4aca-90cc-ebc02e683f35")

for coding in condition.codings.all():
    log.info(f"system:  {coding.system}")
    log.info(f"code:    {coding.code}")
    log.info(f"display: {coding.display}")

Filtering #

Conditions can be filtered by any attribute that exists on the model.

Filtering for conditions is done with the filter method on the Condition model manager.

By attribute #

Specify an attribute with filter to filter by that attribute:

from canvas_sdk.v1.data.condition import Condition

conditions = Condition.objects.filter(onset_date__gte="2024-10-15")

By ValueSet #

Filtering by ValueSet works a little differently. The find method on the model manager is used to perform ValueSet filtering:

from canvas_sdk.v1.data.condition import Condition
from canvas_sdk.value_set.v022.condition import Diabetes

conditions = Condition.objects.find(Diabetes)

Attributes #

Condition #

Field NameType
idUUID
dbidInteger
deletedBoolean
entered_in_errorCanvasUser
committerCanvasUser
patientPatient
onset_dateDate
resolution_dateDate
clinical_statusClinicalStatus
codingsConditionCoding[]
lab_order_reason_conditionsLabOrderReasonConditionCoding[]

ConditionCoding #

Field NameType
dbidInteger
systemString
versionString
codeString
displayString
user_selectedBoolean
conditionCondition

Enumeration types #

ClinicalStatus #

ValueLabel
activeactive
relapserelapse
remissionremission
resolvedresolved
investigativeinvestigative