SDES2EPT ;ALB/LAB,ANU - SDES2 GET PATIENT'S ExtendedProfile APPT INFO ; DEC 14,2023
;;5.3;Scheduling;**861,867**;Aug 13, 1993;Build 8
;;Per VHA Directive 6402, this routine should not be modified
;
Q
;
; Documented API's and Integration Agreements
; -------------------------------------------
; Reference to INP^DGPMV10 supported by ICR #7035
; Reference to ELIG^VADPT supported by ICR #10061
; Reference to Patient File supported by ICR #7019
; #10035 - ^DPT( references (Supported)
;
; RPC: SDES2 GET PATIENT EPT
;
; SDCONTEXT("ACHERON AUDIT ID") = 36 character unique ID number. Ex: 11d9dcc6-c6a2-4785-8031-8261576fca37
; SDCONTEXT("USER DUZ") = The DUZ of the user taking action on the calling application.
; SDCONTEXT("USER NAME") = The name of the user taking action on the calling application.
; SDCONTEXT("PATIENT DFN") = The DFN of the patient taking action on the calling application.
; SDCONTEXT("PATIENT ICN") = The ICN of the patient taking action on the calling application.
; SDINPUT("PATIENT DFN") = Patient to pull data for
;
Q
;
GETPTIN(JSONRETURN,SDCONTEXT,SDINPUT) ; Get Patient's ExtendedProfile Appt Info
N SDAPPTDT,SDDFN,SDERRORS,SDRETURN,VALRET
;
; Validate SDCONTEXT
;
D VALCONTEXT^SDES2VALCONTEXT(.SDERRORS,.SDCONTEXT)
I $D(SDERRORS) M SDRETURN=SDERRORS S SDRETURN("ExtendedProfile",1)="" D BUILDJSON^SDES2JSON(.JSONRETURN,.SDRETURN) Q
; Checking DFN separately, since it's required for this RPC
D VALFILEIEN^SDES2VALUTIL(.VALRET,.SDERRORS,2,$G(SDINPUT("PATIENT DFN")),1,0,1,2)
I 'VALRET,$D(SDERRORS) M SDRETURN=SDERRORS S SDRETURN("ExtendedProfile",1)="" D BUILDJSON^SDES2JSON(.JSONRETURN,.SDRETURN) Q
S SDDFN=SDINPUT("PATIENT DFN")
;
;
; Retrieve Patient's ExtendedProfile Appt Info
;
D GETPTINA(.SDRETURN,SDDFN)
;
; Build JSON return
;
I '$D(SDRETURN) S SDRETURN("ExtendedProfile",1)=""
D BUILDJSON^SDES2JSON(.JSONRETURN,.SDRETURN)
Q
;
GETPTINA(SDRETURN,SDDFN) ;
N SDCOUNT,SDRESULT,PATIENTDATA,SDPOS,SDPOSN,SDCMBTV,SDCMBTVED,SDPOW,SDSW,DFN,VASV
N SDSTAT,SDST,SDSTA,SDLADMT,SDA,VAEL
S SDCOUNT=1
S DFN=SDDFN
; .323 - Period of Service
D ELIG^VADPT,SVC^VADPT
S SDRETURN("ExtendedProfile",SDCOUNT,"Period of Service IEN")=$P(VAEL(2),U,1)
S SDRETURN("ExtendedProfile",SDCOUNT,"Period of Service Name")=$P(VAEL(2),U,2)
;
D GETS^DIQ(2,SDDFN,".01;.135;.525;.322013","IE","PATIENTDATA")
S SDRETURN("ExtendedProfile",SDCOUNT,"DFN")=SDDFN
S SDRETURN("ExtendedProfile",SDCOUNT,"Name")=$G(PATIENTDATA(2,SDDFN_",",.01,"E"))
; COMBAT VETERAN
I $G(VASV(5)) D
. S SDCMBTV="Yes"
. S SDCMBTVED=$P($G(VASV(5,2)),U,2)
I '$G(VASV(5)) D
. S SDCMBTV="No"
. S SDCMBTVED="N/A"
S SDRETURN("ExtendedProfile",SDCOUNT,"Combat Veteran")=$G(SDCMBTV)
;867
I SDCMBTV="No" S SDRETURN("ExtendedProfile",SDCOUNT,"Combat Veteran End Date")=$G(SDCMBTVED)
I SDCMBTV'="No" S SDRETURN("ExtendedProfile",SDCOUNT,"Combat Veteran End Date")=$$FMTISO^SDAMUTDT($$CONVDATE^SDESCOMPPEN($G(SDCMBTVED)))
;
; PRISONER OF WAR - VADPT is not handling Unknown value
I $G(PATIENTDATA(2,SDDFN_",",.525,"I"))="Y" S SDPOW="Yes"
I $G(PATIENTDATA(2,SDDFN_",",.525,"I"))="N" S SDPOW="No"
I $G(PATIENTDATA(2,SDDFN_",",.525,"I"))="U" S SDPOW="Unknown"
S SDRETURN("ExtendedProfile",SDCOUNT,"Prisoner of War")=$G(SDPOW)
;
; PAGER NUMBER
S SDRETURN("ExtendedProfile",SDCOUNT,"Pager Number")=$G(PATIENTDATA(2,SDDFN_",",.135,"I"))
; SW ASIA CONDITIONS
I $G(PATIENTDATA(2,SDDFN_",",.322013,"I"))="Y" S SDSW="Yes"
I $G(PATIENTDATA(2,SDDFN_",",.322013,"I"))="N" S SDSW="No"
I $G(PATIENTDATA(2,SDDFN_",",.322013,"I"))="U" S SDSW="Unknown"
S SDRETURN("ExtendedProfile",SDCOUNT,"SW Asia Conditions")=$G(SDSW)
; STATUS, LAST ADMIT/LODGER DATE
S (SDLADMT,SDSTAT,SDST,SDSTA,SDA)=""
S SDRETURN("ExtendedProfile",SDCOUNT,"Status")=$G(SDSTAT)
S SDRETURN("ExtendedProfile",SDCOUNT,"Last Admit/Lodger Date")=$G(SDLADMT)
I '$D(^DGPM("C",SDDFN)) S SDSTAT="NO INPT./LOD. ACT." Q
;
S VAIP("D")="L",VAIP("L")="" D INP^DGPMV10
S SDA=$S("^3^5^"[("^"_+DGPMVI(2)_"^"):0,1:+DGPMVI(2)),SDST=$S('SDA:"IN",1:"")_"ACTIVE ",SDSTA=$S("^4^5^"[("^"_+DGPMVI(2)_"^"):"LODGER",1:"INPATIENT")
S SDSTAT="" S SDSTAT=SDST_SDSTA
S SDLADMT="" S SDLADMT=$P($G(DGPMVI(13,1)),"^",2)
S SDRETURN("ExtendedProfile",SDCOUNT,"Status")=$G(SDSTAT)
;867
;S SDRETURN("ExtendedProfile",SDCOUNT,"Last Admit/Lodger Date")=$G(SDLADMT)
S SDRETURN("ExtendedProfile",SDCOUNT,"Last Admit/Lodger Date")=$$FMTISO^SDAMUTDT($$CONVDATE^SDESCOMPPEN($G(SDLADMT)))
K DGPMVI,VAIP
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HSDES2EPT 4578 printed Apr 09, 2024@21:54:06 Page 2
SDES2EPT ;ALB/LAB,ANU - SDES2 GET PATIENT'S ExtendedProfile APPT INFO ; DEC 14,2023
+1 ;;5.3;Scheduling;**861,867**;Aug 13, 1993;Build 8
+2 ;;Per VHA Directive 6402, this routine should not be modified
+3 ;
+4 QUIT
+5 ;
+6 ; Documented API's and Integration Agreements
+7 ; -------------------------------------------
+8 ; Reference to INP^DGPMV10 supported by ICR #7035
+9 ; Reference to ELIG^VADPT supported by ICR #10061
+10 ; Reference to Patient File supported by ICR #7019
+11 ; #10035 - ^DPT( references (Supported)
+12 ;
+13 ; RPC: SDES2 GET PATIENT EPT
+14 ;
+15 ; SDCONTEXT("ACHERON AUDIT ID") = 36 character unique ID number. Ex: 11d9dcc6-c6a2-4785-8031-8261576fca37
+16 ; SDCONTEXT("USER DUZ") = The DUZ of the user taking action on the calling application.
+17 ; SDCONTEXT("USER NAME") = The name of the user taking action on the calling application.
+18 ; SDCONTEXT("PATIENT DFN") = The DFN of the patient taking action on the calling application.
+19 ; SDCONTEXT("PATIENT ICN") = The ICN of the patient taking action on the calling application.
+20 ; SDINPUT("PATIENT DFN") = Patient to pull data for
+21 ;
+22 QUIT
+23 ;
GETPTIN(JSONRETURN,SDCONTEXT,SDINPUT) ; Get Patient's ExtendedProfile Appt Info
+1 NEW SDAPPTDT,SDDFN,SDERRORS,SDRETURN,VALRET
+2 ;
+3 ; Validate SDCONTEXT
+4 ;
+5 DO VALCONTEXT^SDES2VALCONTEXT(.SDERRORS,.SDCONTEXT)
+6 IF $DATA(SDERRORS)
MERGE SDRETURN=SDERRORS
SET SDRETURN("ExtendedProfile",1)=""
DO BUILDJSON^SDES2JSON(.JSONRETURN,.SDRETURN)
QUIT
+7 ; Checking DFN separately, since it's required for this RPC
+8 DO VALFILEIEN^SDES2VALUTIL(.VALRET,.SDERRORS,2,$GET(SDINPUT("PATIENT DFN")),1,0,1,2)
+9 IF 'VALRET
IF $DATA(SDERRORS)
MERGE SDRETURN=SDERRORS
SET SDRETURN("ExtendedProfile",1)=""
DO BUILDJSON^SDES2JSON(.JSONRETURN,.SDRETURN)
QUIT
+10 SET SDDFN=SDINPUT("PATIENT DFN")
+11 ;
+12 ;
+13 ; Retrieve Patient's ExtendedProfile Appt Info
+14 ;
+15 DO GETPTINA(.SDRETURN,SDDFN)
+16 ;
+17 ; Build JSON return
+18 ;
+19 IF '$DATA(SDRETURN)
SET SDRETURN("ExtendedProfile",1)=""
+20 DO BUILDJSON^SDES2JSON(.JSONRETURN,.SDRETURN)
+21 QUIT
+22 ;
GETPTINA(SDRETURN,SDDFN) ;
+1 NEW SDCOUNT,SDRESULT,PATIENTDATA,SDPOS,SDPOSN,SDCMBTV,SDCMBTVED,SDPOW,SDSW,DFN,VASV
+2 NEW SDSTAT,SDST,SDSTA,SDLADMT,SDA,VAEL
+3 SET SDCOUNT=1
+4 SET DFN=SDDFN
+5 ; .323 - Period of Service
+6 DO ELIG^VADPT
DO SVC^VADPT
+7 SET SDRETURN("ExtendedProfile",SDCOUNT,"Period of Service IEN")=$PIECE(VAEL(2),U,1)
+8 SET SDRETURN("ExtendedProfile",SDCOUNT,"Period of Service Name")=$PIECE(VAEL(2),U,2)
+9 ;
+10 DO GETS^DIQ(2,SDDFN,".01;.135;.525;.322013","IE","PATIENTDATA")
+11 SET SDRETURN("ExtendedProfile",SDCOUNT,"DFN")=SDDFN
+12 SET SDRETURN("ExtendedProfile",SDCOUNT,"Name")=$GET(PATIENTDATA(2,SDDFN_",",.01,"E"))
+13 ; COMBAT VETERAN
+14 IF $GET(VASV(5))
Begin DoDot:1
+15 SET SDCMBTV="Yes"
+16 SET SDCMBTVED=$PIECE($GET(VASV(5,2)),U,2)
End DoDot:1
+17 IF '$GET(VASV(5))
Begin DoDot:1
+18 SET SDCMBTV="No"
+19 SET SDCMBTVED="N/A"
End DoDot:1
+20 SET SDRETURN("ExtendedProfile",SDCOUNT,"Combat Veteran")=$GET(SDCMBTV)
+21 ;867
+22 IF SDCMBTV="No"
SET SDRETURN("ExtendedProfile",SDCOUNT,"Combat Veteran End Date")=$GET(SDCMBTVED)
+23 IF SDCMBTV'="No"
SET SDRETURN("ExtendedProfile",SDCOUNT,"Combat Veteran End Date")=$$FMTISO^SDAMUTDT($$CONVDATE^SDESCOMPPEN($GET(SDCMBTVED)))
+24 ;
+25 ; PRISONER OF WAR - VADPT is not handling Unknown value
+26 IF $GET(PATIENTDATA(2,SDDFN_",",.525,"I"))="Y"
SET SDPOW="Yes"
+27 IF $GET(PATIENTDATA(2,SDDFN_",",.525,"I"))="N"
SET SDPOW="No"
+28 IF $GET(PATIENTDATA(2,SDDFN_",",.525,"I"))="U"
SET SDPOW="Unknown"
+29 SET SDRETURN("ExtendedProfile",SDCOUNT,"Prisoner of War")=$GET(SDPOW)
+30 ;
+31 ; PAGER NUMBER
+32 SET SDRETURN("ExtendedProfile",SDCOUNT,"Pager Number")=$GET(PATIENTDATA(2,SDDFN_",",.135,"I"))
+33 ; SW ASIA CONDITIONS
+34 IF $GET(PATIENTDATA(2,SDDFN_",",.322013,"I"))="Y"
SET SDSW="Yes"
+35 IF $GET(PATIENTDATA(2,SDDFN_",",.322013,"I"))="N"
SET SDSW="No"
+36 IF $GET(PATIENTDATA(2,SDDFN_",",.322013,"I"))="U"
SET SDSW="Unknown"
+37 SET SDRETURN("ExtendedProfile",SDCOUNT,"SW Asia Conditions")=$GET(SDSW)
+38 ; STATUS, LAST ADMIT/LODGER DATE
+39 SET (SDLADMT,SDSTAT,SDST,SDSTA,SDA)=""
+40 SET SDRETURN("ExtendedProfile",SDCOUNT,"Status")=$GET(SDSTAT)
+41 SET SDRETURN("ExtendedProfile",SDCOUNT,"Last Admit/Lodger Date")=$GET(SDLADMT)
+42 IF '$DATA(^DGPM("C",SDDFN))
SET SDSTAT="NO INPT./LOD. ACT."
QUIT
+43 ;
+44 SET VAIP("D")="L"
SET VAIP("L")=""
DO INP^DGPMV10
+45 SET SDA=$SELECT("^3^5^"[("^"_+DGPMVI(2)_"^"):0,1:+DGPMVI(2))
SET SDST=$SELECT('SDA:"IN",1:"")_"ACTIVE "
SET SDSTA=$SELECT("^4^5^"[("^"_+DGPMVI(2)_"^"):"LODGER",1:"INPATIENT")
+46 SET SDSTAT=""
SET SDSTAT=SDST_SDSTA
+47 SET SDLADMT=""
SET SDLADMT=$PIECE($GET(DGPMVI(13,1)),"^",2)
+48 SET SDRETURN("ExtendedProfile",SDCOUNT,"Status")=$GET(SDSTAT)
+49 ;867
+50 ;S SDRETURN("ExtendedProfile",SDCOUNT,"Last Admit/Lodger Date")=$G(SDLADMT)
+51 SET SDRETURN("ExtendedProfile",SDCOUNT,"Last Admit/Lodger Date")=$$FMTISO^SDAMUTDT($$CONVDATE^SDESCOMPPEN($GET(SDLADMT)))
+52 KILL DGPMVI,VAIP
+53 QUIT