def submit_hpi_view(request, patient_id=None, encounter_id=None, hpi_id=None): if request.user.is_authenticated: if request.user.current_campaign == "RECOVERY MODE": return_response = redirect("main:home") elif request.method == "POST": encounter = get_object_or_404(PatientEncounter, pk=encounter_id) history = HistoryOfPresentIllness.objects.get(pk=hpi_id) aux_form = HistoryOfPresentIllnessForm(request.POST, instance=history) if aux_form.is_valid(): updated_history = aux_form.save() updated_history.save() DatabaseChangeLog.objects.create( action="Edit", model="PatientEncounter", instance=str(encounter), ip=get_client_ip(request), username=request.user.username, campaign=Campaign.objects.get( name=request.user.current_campaign), ) if os.environ.get("QLDB_ENABLED") == "TRUE": encounter_data = PatientEncounterSerializer(encounter).data update_patient_encounter(encounter_data) return_response = redirect("main:hpi_view", patient_id=patient_id, encounter_id=encounter_id) else: return_response = redirect("/not_logged_in") return return_response
def __aux_form_is_valid(request, encounter, treatment_form): encounter.procedure = request.POST["procedure"] encounter.pharmacy_notes = request.POST["pharmacy_notes"] encounter.save() querysets = list(PatientDiagnosis.objects.filter(encounter=encounter)) if len(querysets) > 0: item = querysets.pop().diagnosis.all() for query_item in querysets: item.union(query_item.diagnosis.all()) treatment_form.fields["diagnosis"].queryset = item else: treatment_form.fields["diagnosis"].queryset = Diagnosis.objects.none() DatabaseChangeLog.objects.create( action="Edit", model="PatientEncounter", instance=str(encounter), ip=get_client_ip(request), username=request.user.username, campaign=Campaign.objects.get(name=request.user.current_campaign), ) if os.environ.get("QLDB_ENABLED") == "TRUE": encounter_data = PatientEncounterSerializer(encounter).data update_patient_encounter(encounter_data) return render( request, "data/encounter_submitted.html", { "patient_id": encounter.patient.id, "encounter_id": encounter.id }, )
def __treatment_view_post(request, encounter): treatment_form = TreatmentForm(request.POST) if treatment_form.is_valid(): treatment = treatment_form.save(commit=False) treatment.encounter = encounter treatment.prescriber = request.user if treatment.administration_schedule is not None: treatment.amount = (treatment.days * treatment.administration_schedule.modifier) else: treatment.amount = 1 treatment.save() treatment_form.save_m2m() for item in treatment.medication.all().iterator(): item.amount -= treatment.amount if item.count > 0: item.quantity = math.ceil(item.amount / item.count) else: item.quantity = item.amount item.save() treatment_form = TreatmentForm() DatabaseChangeLog.objects.create( action="Edit", model="PatientEncounter", instance=str(encounter), ip=get_client_ip(request), username=request.user.username, campaign=Campaign.objects.get(name=request.user.current_campaign), ) if os.environ.get("QLDB_ENABLED") == "TRUE": encounter_data = PatientEncounterSerializer(encounter).data update_patient_encounter(encounter_data) return treatment_form
def new_diagnosis_view_post(request, encounter, diagnosis_set): if len(diagnosis_set) > 0: diagnosis_form = PatientDiagnosisForm(request.POST, instance=diagnosis_set[0]) else: diagnosis_form = PatientDiagnosisForm(request.POST) if diagnosis_form.is_valid(): if len(diagnosis_set) > 1: PatientDiagnosis.objects.exclude(pk=diagnosis_set[0].id).delete() diagnosis = diagnosis_form.save(commit=False) diagnosis.encounter = encounter diagnosis.save() diagnosis_form.save_m2m() DatabaseChangeLog.objects.create( action="Edit", model="PatientEncounter", instance=str(encounter), ip=get_client_ip(request), username=request.user.username, campaign=Campaign.objects.get(name=request.user.current_campaign), ) if os.environ.get("QLDB_ENABLED") == "TRUE": encounter_data = PatientEncounterSerializer(encounter).data update_patient_encounter(encounter_data) return diagnosis_form
def referral_form_view(request, patient_id=None): if request.method == "POST": patient = Patient.objects.get(pk=patient_id) patient.campaign.add(Campaign.objects.get(pk=request.POST["campaign"])) patient.save() if os.environ.get("QLDB_ENABLED") == "TRUE": update_patient_encounter( {"patient": patient.id, "campaign": request.POST["campaign"]} ) return_response = redirect("main:patient_list_view") elif request.method == "GET": return_response = render( request, "forms/referral.html", { "patient_id": patient_id, "page_name": "Campaign Referral", "campaigns": Campaign.objects.filter( instance=Campaign.objects.get( name=request.user.current_campaign ).instance ).filter(active=True), }, ) return return_response
def new_vitals_view_post(request, units, encounter): vitals_form = VitalsForm(request.POST, unit=units) if vitals_form.is_valid(): vitals = vitals_form.save(commit=False) vitals.encounter = encounter vitals.save() DatabaseChangeLog.objects.create( action="New", model="Vitals", instance=str(encounter), ip=get_client_ip(request), username=request.user.username, campaign=Campaign.objects.get(name=request.user.current_campaign), ) if os.environ.get("QLDB_ENABLED") == "TRUE": encounter_data = PatientEncounterSerializer(encounter).data update_patient_encounter(encounter_data)
def __edit_photo_view_post(request, patient_id, encounter_id, photo_id): units = Campaign.objects.get(name=request.user.current_campaign).units encounter = get_object_or_404(PatientEncounter, pk=encounter_id) patient = get_object_or_404(Patient, pk=patient_id) photo = Photo.objects.get(pk=photo_id) aux_form = PhotoForm(request.POST, request.FILES, instance=photo) if aux_form.is_valid(): photo = aux_form.save() try: photo.save() except ValueError: photo.delete() DatabaseChangeLog.objects.create( action="Edit", model="Photo", instance=str(photo), ip=get_client_ip(request), username=request.user.username, campaign=Campaign.objects.get(name=request.user.current_campaign), ) if os.environ.get("QLDB_ENABLED") == "TRUE": encounter_data = PatientEncounterSerializer(encounter).data update_patient_encounter(encounter_data) vitals_form = VitalsForm(unit=units) suffix = patient.get_suffix_display( ) if patient.suffix is not None else "" return render( request, "forms/photos_tab.html", { "aux_form": aux_form, "vitals": Vitals.objects.filter(encounter=encounter), "treatments": Treatment.objects.filter(encounter=encounter), "vitals_form": vitals_form, "page_name": f"Edit Encounter for {patient.first_name} {patient.last_name} {suffix}", "encounter": encounter, "birth_sex": patient.sex_assigned_at_birth, "encounter_id": encounter_id, "patient_name": f"{patient.first_name} {patient.last_name} {suffix}", "units": units, "patient": patient, }, )
def __upload_photo_view_post(request, encounter): aux_form = PhotoForm(request.POST, request.FILES) if aux_form.is_valid(): photo = aux_form.save() photo.save() encounter.photos.add(photo) encounter.save() aux_form = PhotoForm() DatabaseChangeLog.objects.create( action="Edit", model="PatientEncounter", instance=str(encounter), ip=get_client_ip(request), username=request.user.username, campaign=Campaign.objects.get(name=request.user.current_campaign), ) if os.environ.get("QLDB_ENABLED") == "TRUE": encounter_data = PatientEncounterSerializer(encounter).data update_patient_encounter(encounter_data) return aux_form
def history_view(request, patient_id=None, encounter_id=None): if request.user.is_authenticated: if request.user.current_campaign == "RECOVERY MODE": return_response = redirect("main:home") else: units = Campaign.objects.get( name=request.user.current_campaign).units encounter = get_object_or_404(PatientEncounter, pk=encounter_id) patient = get_object_or_404(Patient, pk=patient_id) aux_form = HistoryPatientEncounterForm(instance=encounter) if request.method == "POST": aux_form = HistoryPatientEncounterForm(request.POST) if aux_form.is_valid(): encounter.medical_history = request.POST["medical_history"] encounter.social_history = request.POST["social_history"] encounter.current_medications = request.POST[ "current_medications"] encounter.family_history = request.POST["family_history"] encounter.save() DatabaseChangeLog.objects.create( action="Edit", model="PatientEncounter", instance=str(encounter), ip=get_client_ip(request), username=request.user.username, campaign=Campaign.objects.get( name=request.user.current_campaign), ) if os.environ.get("QLDB_ENABLED") == "TRUE": encounter_data = PatientEncounterSerializer( encounter).data update_patient_encounter(encounter_data) return_response = render( request, "data/encounter_submitted.html", { "patient_id": patient_id, "encounter_id": encounter_id }, ) else: form = PatientEncounterForm(instance=encounter, unit=units) vitals_form = VitalsForm(unit=units) if units == "i": history_view_imperial(form, encounter) suffix = (patient.get_suffix_display() if patient.suffix is not None else "") return_response = render( request, "forms/history_tab.html", { "form": form, "aux_form": aux_form, "vitals": Vitals.objects.filter(encounter=encounter), "treatments": Treatment.objects.filter(encounter=encounter), "vitals_form": vitals_form, "page_name": f"Edit Encounter for {patient.first_name} {patient.last_name} {suffix}", "encounter": encounter, "birth_sex": patient.sex_assigned_at_birth, "patient_id": patient_id, "encounter_id": encounter_id, "patient_name": f"{patient.first_name} {patient.last_name} {suffix}", "units": units, "patient": patient, }, ) else: return_response = __history_view_get(request, encounter_id, units, patient, aux_form) else: return_response = redirect("/not_logged_in") return return_response
def __encounter_edit_form_post(request, patient_id, encounter_id): encounter = get_object_or_404(PatientEncounter, pk=encounter_id) patient = get_object_or_404(Patient, pk=patient_id) units = Campaign.objects.get(name=request.user.current_campaign).units photos = encounter.photos.all().iterator() treatments = Treatment.objects.filter(encounter=encounter) form = PatientEncounterForm(request.POST or None, instance=encounter, unit=units) if form.is_valid(): encounter = form.save(commit=False) form.save_m2m() encounter.patient = patient encounter.active = True encounter.photos.set(photos) encounter.save() DatabaseChangeLog.objects.create( action="Edit", model="PatientEncounter", instance=str(encounter), ip=get_client_ip(request), username=request.user.username, campaign=Campaign.objects.get(name=request.user.current_campaign), ) if os.environ.get("QLDB_ENABLED") == "TRUE": encounter_data = PatientEncounterSerializer(encounter).data update_patient_encounter(encounter_data) if "submit_encounter" in request.POST: return_response = render( request, "data/encounter_submitted.html", { "patient_id": patient_id, "encounter_id": encounter_id }, ) elif "submit_refer" in request.POST: kwargs = {"patient_id": patient_id} return_response = redirect("main:referral_form_view", **kwargs) else: return_response = render( request, "data/encounter_submitted.html", { "patient_id": patient_id, "encounter_id": encounter_id }, ) else: form.initial["timestamp"] = encounter.timestamp encounter_active = encounter.active suffix = patient.get_suffix_display( ) if patient.suffix is not None else "" return_response = render( request, "forms/edit_encounter.html", { "active": encounter_active, "aux_form": AuxiliaryPatientEncounterForm(), "form": form, "vitals": Vitals.objects.filter(encounter=encounter), "treatments": treatments, "vitals_form": VitalsForm(unit=units), "page_name": f"Edit Encounter for {patient.first_name} {patient.last_name} {suffix}", "encounter": encounter, "birth_sex": patient.sex_assigned_at_birth, "encounter_id": encounter_id, "patient_name": f"{patient.first_name} {patient.last_name} {suffix}", "units": units, "patient": patient, }, ) return return_response