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 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
def __patient_encounter_form_post(request, patient): telehealth = Campaign.objects.get(name=request.user.current_campaign).telehealth units = Campaign.objects.get(name=request.user.current_campaign).units encounter_open = ( len(PatientEncounter.objects.filter(patient=patient).filter(active=True)) > 0 ) form = PatientEncounterForm(request.POST, unit=units, prefix="form") vitals_form = VitalsForm(request.POST, unit=units, prefix="vitals_form") treatment_form = TreatmentForm() diagnosis_form = DiagnosisForm() if form.is_valid() and vitals_form.is_valid(): encounter = form.save(commit=False) vitals = vitals_form.save(commit=False) encounter.patient = patient encounter.active = True encounter.campaign = Campaign.objects.get(name=request.user.current_campaign) encounter.save() vitals.encounter = encounter vitals.save() form.save_m2m() if os.environ.get("QLDB_ENABLED") == "TRUE": encounter_data = PatientEncounterSerializer(encounter).data create_new_patient_encounter(encounter_data) DatabaseChangeLog.objects.create( action="Create", model="PatientEncounter", instance=str(encounter), ip=get_client_ip(request), username=request.user.username, campaign=Campaign.objects.get(name=request.user.current_campaign), ) DatabaseChangeLog.objects.create( action="Create", model="Vitals", instance=str(encounter), ip=get_client_ip(request), username=request.user.username, campaign=Campaign.objects.get(name=request.user.current_campaign), ) 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: suffix = patient.get_suffix_display() if patient.suffix is not None else "" return_response = render( request, "forms/encounter.html", { "form": form, "vitals_form": vitals_form, "diagnosis_form": diagnosis_form, "treatment_form": treatment_form, "page_name": f"New Encounter for {patient.first_name} {patient.last_name} {suffix}", "birth_sex": patient.sex_assigned_at_birth, "patient_id": patient.id, "units": units, "telehealth": telehealth, "encounter_open": encounter_open, "page_tip": "Complete form with patient vitals as instructed. " "Any box with an asterisk (*) is required. " "For max efficiency, use 'tab' to navigate through this page.", }, ) return return_response