Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: ORQQVS

ORQQVS.m

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