VistA-FOIAVistA/r/ORDER_ENTRY_RESULTS_REPORTI.../ORQQVS.m

94 lines
3.9 KiB
Mathematica

ORQQVS ; slc/CLA,STAFF - Functions which return patient visits ;3/16/05 10:27
;;3.0;ORDER ENTRY/RESULTS REPORTING;**10,195,215,271**;Dec 17, 1997;Build 2
;
; DBIA 2812 NOTES^TIUSRVLV ^TMP("TIULIST",$J)
; DBIA 2944 TGET^TIUSRVR1 ^TMP("TIUVIEW",$J)
; DBIA 1905 SELECTED^VSIT ^TMP("VSIT",$J)
;
LIST(ORY,PT,ORSDT,OREDT,LOC) ; return visits for a patient between start & end dates for a location, if no location return all visits
N VIEN,NUM,CNT,INVDT,ORSRV,CNTLIMIT,ORX
S CNTLIMIT=100 ;limit visits to 100 most recent Visit entries
S VIEN="A",NUM=0,CNT=1
S ORSRV=$G(^VA(200,DUZ,5)) I +ORSRV>0 S ORSRV=$P(ORSRV,U)
I ORSDT="" D
.I '$L(LOC) S ORSDT=$$UP^XLFSTR($$GET^XPAR("USR^SRV.`"_+$G(ORSRV)_"^DIV^SYS^PKG","ORQQEAPT ENC APPT START",1,"E"))
.I ORSDT="" S ORSDT="T-730" ;default start date is two years ago
I OREDT="" D
.I '$L(LOC) S OREDT=$$UP^XLFSTR($$GET^XPAR("USR^SRV.`"_+$G(ORSRV)_"^DIV^SYS^PKG","ORQQEAPT ENC APPT STOP",1,"E"))
.I OREDT="" S OREDT="T" ;default end date is today
;CONVERT ORSDT AND OREDT INTO FILEMAN DATE/TIME
D DT^DILF("T",ORSDT,.ORSDT,"","")
D DT^DILF("T",OREDT,.OREDT,"","")
I (ORSDT=-1)!(OREDT=-1) S ORY(1)="^Error in date range." Q
K ^TMP("VSIT",$J) ;DBIA 1905
D SELECTED^VSIT(PT,ORSDT,OREDT,LOC,"") ;DBIA 1905
F S VIEN=$O(^TMP("VSIT",$J,VIEN),-1) Q:VIEN=""!(CNT>CNTLIMIT) D
.F S NUM=$O(^TMP("VSIT",$J,VIEN,NUM)) Q:NUM="" D
..S ORX=^TMP("VSIT",$J,VIEN,NUM),INVDT=9999999-$P(ORX,U)
..I $$ACTLOC^ORWU(+$P(ORX,U,2))=1 D
...S ORY(CNT)=VIEN_U_ORX_U_INVDT,CNT=CNT+1
K ^TMP("VSIT",$J)
Q
VSITAPPT(ORVY,PT,SDT,EDT,DUMMY) ; return past visits and future appointments for a patient between start and end dates
N NDT,CNT,I,TS,ORVSITY K ORVY D NOW^%DTC S NDT=+%,CNT=1 K %
D PTAPPTS^ORQPTQ2(.ORYA,PT,NDT,EDT,"") ;get future appointments
S I=0 F S I=$O(ORYA(I)) Q:I<1 I ORYA(I)'["No appts",+ORYA(I) D
.S ORVY(CNT)=$P(ORYA(I),U)_";s"_U_$P(ORYA(I),U,2)_U_"sched:"_U_$P(ORYA(I),U)
.S ORVY(CNT)=ORVY(CNT)_U_$P(ORYA(I),U,5),CNT=CNT+1
D LIST(.YV,PT,SDT,NDT,"") ;get past visits
S I=0 F S I=$O(YV(I)) Q:I<1 D
.S ORVY(CNT)=$P(YV(I),U)_";v"_U_$P($P(YV(I),U,3),";",2)
.I $P(YV(I),U,4)="H" D
..S ORVY(CNT)=$P(YV(I),U)_";a"_U_"Inpatient Stay"_U_"admitted:"
.I $P(YV(I),U,4)'="H" S ORVY(CNT)=ORVY(CNT)_U_"visited:"
.S ORVY(CNT)=ORVY(CNT)_U_$P(YV(I),U,2)_U_$P(YV(I),U,8),CNT=CNT+1
S:+$G(ORVY(1))<1 ORVY(1)="^No appts or visits found."
S TSTDT=DT_".2359"
D DT^DILF("T",EDT,.EDT,"","")
I (EDT>TSTDT) D
. I '$L($P($G(ORYA(1)),U)),$L($P($G(ORYA(1)),U,2)),'$L($O(ORYA(1))) D
. . K ORVY S ORVY(1)=ORYA(1)
K ORYA,YV
Q
DETNOTE(ORVY,ORPT,ORVIEN) ;return progress notes for a patient's visit
N ORTY,ORY,TDT,ORVI
S TDT=0
K ^TMP("TIULIST",$J) ;DBIA 2812
D NOTES^TIUSRVLV(.ORY,ORVIEN) ;DBIA 2812
I '+$O(^TMP("TIULIST",$J,0)) D Q
. S ORVY(1)="No Progress Notes for this visit."
S ORVI=1
F S TDT=$O(^TMP("TIULIST",$J,TDT)) Q:+TDT'>0 D
. N SEQ,TIEN S SEQ=0
. F S SEQ=$O(^TMP("TIULIST",$J,TDT,SEQ)) Q:+SEQ'>0 D
. . N TSEQ K ^TMP("TIUVIEW",$J) ;DBIA 2944
. . S TIEN=$P(^TMP("TIULIST",$J,TDT,SEQ),U)
. . D TGET^TIUSRVR1(.ORTY,TIEN) ;DBIA 2944
. . S TSEQ=0
. . F S TSEQ=$O(@ORTY@(TSEQ)) Q:TSEQ="" D
. . . S ORVY(ORVI)=@ORTY@(TSEQ),ORVI=ORVI+1
. . S ORVY(ORVI)=" ",ORVI=ORVI+1
. . S ORVY(ORVI)=" ",ORVI=ORVI+1
K ^TMP("TIULIST",$J)
Q
DETSUM(ORVY,ORPT,ORVIEN) ;return discharge summary for a patient's visit
N CR,ORTY,ORY,TDT
S TDT=0
K ^TMP("TIULIST",$J)
D SUMMARY^TIUSRVLV(.ORY,ORVIEN)
I '+$O(^TMP("TIULIST",$J,0)) D Q
. S ORVY(1)="No Discharge Summary found for this stay."
F S TDT=$O(^TMP("TIULIST",$J,TDT)) Q:+TDT'>0 D
. N SEQ,TIEN S SEQ=0
. F S SEQ=$O(^TMP("TIULIST",$J,TDT,SEQ)) Q:+SEQ'>0 D
. . N TSEQ,ORVI K ^TMP("TIUVIEW",$J)
. . S TIEN=$P(^TMP("TIULIST",$J,TDT,SEQ),U)
. . D TGET^TIUSRVR1(.ORTY,TIEN)
. . S TSEQ=0,ORVI=1
. . F S TSEQ=$O(@ORTY@(TSEQ)) Q:TSEQ="" D
. . . S ORVY(ORVI)=@ORTY@(TSEQ),ORVI=ORVI+1
. . S ORVY(ORVI)=" ",ORVI=ORVI+1
. . S ORVY(ORVI)=" ",ORVI=ORVI+1
K ^TMP("TIULIST",$J)
Q