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

PXBGVST.m

Go to the documentation of this file.
  1. PXBGVST ;ISL/JVS - GATHER ENCOUNTERS ;8/28/96
  1. ;;1.0;PCE PATIENT CARE ENCOUNTER;**1**;Aug 12, 1996
  1. ;
  1. ;
  1. ;
  1. VISITLST(DFN,BEGINDT,ENDDT,HLOC,SCREEN,APPOINT,PROMPT,COSTATUS) ;--GATHER VISITS
  1. ;
  1. ; DFN = Patient Identification entry number (required)
  1. ; BEGINDT = Begining date of date range-INTERNAL FORMAT (optional)
  1. ; ENDDT = Ending date of date range-INTERNAL FORMAT (optional)
  1. ; HLOC = Hospital Location (pointer to file#44) (optional)
  1. ; SCREEN = Code as related to field 15003 (optional)
  1. ;
  1. ; ..'A'=ANCILLARY
  1. ; ..'P'=PRIMARY
  1. ; ..'O'=OCCASION OF SERIVCE
  1. ; ..'S'=STOP CODES
  1. ; ..'X'=All three above plus the 'NULL' Encounters (DEFAULT)
  1. ;
  1. ; ..'E'=Historical Encounters ('XE' for all historical visits)
  1. ;
  1. ; APPOINT
  1. ; ..-1
  1. ; ..0
  1. ; ..1
  1. ; OUTPUT:
  1. ; >0 = VISIT IEN
  1. ; =0 = User selected to add a visit
  1. ; -1 = No visit selected
  1. ; -2^"TEXT" = error of some kind^mesage about error
  1. ;
  1. ;
  1. ;--Validate A PATIENT visit is sent in
  1. I $G(DFN)<1 Q -2_"^"_"NO PATIENT"
  1. I '$D(^AUPNPAT(DFN)) Q -2_"^"_"NO SUCH PATIENT"
  1. ;
  1. ;--If no date range then default it
  1. I BEGINDT<1500000!(ENDDT<1500000) D
  1. . N X1,X2,%H,%T
  1. . S X1=DT,X2=+$P(^PX(815,1,"LM"),"^",3) D C^%DTC S BEGINDT=$S(BEGINDT>X:BEGINDT,1:X)
  1. . S X1=DT,X2=+$P(^PX(815,1,"LM"),"^",4) D C^%DTC S ENDDT=X
  1. ;
  1. N STOP
  1. I $G(HLOC) D Q:$G(STOP) -2_"^"_"NO SUCH HOSPITAL LOCATION"
  1. .I '$D(^SC(HLOC)) S STOP=1
  1. ;
  1. ;--NEW variables
  1. N IEN,INDATEI,INDATEE,PXBC,PXBCC,VST,PXBI,SCRN,SCRN1,ENDDTT,BEGINDTT
  1. N PXBHIGH,PXBCNT,PXBWIN,PXBSAVE,PXBDT,DEL,NOD0,NOD150,UID,STATUS
  1. N HLOCE,HLOCI,VAL,VAR
  1. S (PXBC,PXBCC)=0
  1. ;--KILL variables
  1. K ^TMP("PXBU",$J),^UTILITY("DIQ1",$J),^TMP("PXBKY",$J),^TMP("PXBSAM",$J),^TMP("PXBSKY",$J),GROUP
  1. ;--CREATE tmp global
  1. ;-SET UP SCREEN
  1. I $D(SCREEN) D
  1. .S PXBI="" F PXBI=1:1:$L(SCREEN) S SCRN($E(SCREEN,PXBI))=""
  1. .I '$D(SCRN) S SCRN("X")=""
  1. I $D(^AUPNVSIT("AA",DFN)) D
  1. .I $G(ENDDT) S ENDDTT=9999999-$P(ENDDT,".",1) S:ENDDT["." ENDDTT=ENDDTT_((ENDDT#1)-(.0001)) S:ENDDT'["." ENDDTT=(ENDDTT)-(.0001) S ENDDT=ENDDTT
  1. .I $G(BEGINDT) S BEGINDTT=9999999-$P(BEGINDT,".",1) S:BEGINDT["." BEGINDTT=BEGINDTT_(BEGINDT#1) S:BEGINDT'["." BEGINDTT=BEGINDTT_".999999" S BEGINDT=BEGINDTT
  1. .I '$G(BEGINDT) S BEGINDT=999999999
  1. .S PXBDT=$S($G(ENDDT):ENDDT,1:"")
  1. .F S PXBDT=$O(^AUPNVSIT("AA",DFN,PXBDT)) Q:PXBDT>BEGINDT Q:PXBDT'>0 D
  1. ..S IEN=0 F S IEN=$O(^AUPNVSIT("AA",DFN,PXBDT,IEN)) Q:IEN="" D
  1. ...;
  1. ...;-----SCREEN-------
  1. ...;----BRING IN ALL NODES
  1. ...S NOD0=$G(^AUPNVSIT(IEN,0)),NOD150=$G(^AUPNVSIT(IEN,150))
  1. ...;--SCREEN OUT HISTORICAL VISITS
  1. ...I $D(SCRN("E")),$P(NOD0,"^",7)'="E" Q
  1. ...I '$D(SCRN("E")),$P(NOD0,"^",7)="E" Q
  1. ...;--SCREEN BASED ON PARAMETER
  1. ...S SCRN1=$P(NOD150,"^",3)
  1. ...I SCRN1="",'$D(SCRN("X")) Q
  1. ...I $D(SCRN("X")) G CON
  1. ...I SCRN1="A",'$D(SCRN("A")) Q
  1. ...I SCRN1="O",'$D(SCRN("O")) Q
  1. ...I SCRN1="P",'$D(SCRN("P")) Q
  1. ...I SCRN1="S",'$D(SCRN("S")) Q
  1. ...I SCRN1="C",'$D(SCRN("C")) Q
  1. CON ...;--CONTINUE
  1. ...;--HOSPITAL LOCATION
  1. ...I $G(HLOC) Q:$P(NOD0,"^",22)'=HLOC
  1. ...I $G(APPOINT)=0 G END
  1. ...;--I RELATED TO APPOINTMENT--APPOINT=1
  1. ...;I $G(APPOINT)>0,$P(NOD0,"^",22)'=+$G(^DPT(DFN,"S",$P(NOD0,"^",1),0)) Q
  1. ...I $G(APPOINT)>0,'$$VSTAPPT^PXUTL1(DFN,$P(NOD0,"^",1),$P(NOD0,"^",22),IEN) Q
  1. ...;--I NOT RELATED TO AN APPOINTMENT--APPOINT=-1
  1. ...;I $G(APPOINT)<0,$P(NOD0,"^",22)=+$G(^DPT(DFN,"S",$P(NOD0,"^",1),0)) Q
  1. ...I $G(APPOINT)<0,$$VSTAPPT^PXUTL1(DFN,$P(NOD0,"^",1),$P(NOD0,"^",22),IEN) Q
  1. END ...;---END OF SCREENS-----
  1. ...;--DISPOSITIONS
  1. ...I $$DISPOSIT^PXUTL1(DFN,$P(NOD0,"^",1),IEN) Q
  1. ...;
  1. ...S PXBC=PXBC+1
  1. ...S ^TMP("PXBU",$J,"VST",IEN)=""
  1. K SCRN,SCRN1
  1. ;
  1. ;
  1. A ;--Set array with the VISITS from the visits
  1. N DIQ,PRIME,PRIMI,PXBDT,VSTDTE,VSTDTI,GROUP
  1. I $D(^TMP("PXBU",$J,"VST")) D
  1. .S IEN=0 F S IEN=$O(^TMP("PXBU",$J,"VST",IEN)) Q:IEN'>0 D
  1. ..S DIC=9000010,DR=".01;.22;15003;15001",DA=IEN,DIQ(0)="EI" D EN^DIQ1
  1. ..S VSTDTE=$G(^UTILITY("DIQ1",$J,9000010,DA,.01,"E"))
  1. ..S VSTDTE=$P(VSTDTE,"@",1)_" "_$P($P(VSTDTE,"@",2),":",1,2)
  1. ..S VSTDTI=$G(^UTILITY("DIQ1",$J,9000010,DA,.01,"I"))
  1. ..S HLOCE=$G(^UTILITY("DIQ1",$J,9000010,DA,.22,"E"))
  1. ..S HLOCI=$G(^UTILITY("DIQ1",$J,9000010,DA,.22,"I"))
  1. ..S PRIME=$G(^UTILITY("DIQ1",$J,9000010,DA,15003,"E"))
  1. ..S PRIMI=$G(^UTILITY("DIQ1",$J,9000010,DA,15003,"I"))
  1. ..S UID=$G(^UTILITY("DIQ1",$J,9000010,DA,15001,"E"))
  1. ..S STATUS=$P($$STATUS^SDPCE(IEN),"^",2)
  1. ..S GROUP=VSTDTE_"^"_VSTDTI_"^"_HLOCE_"^"_HLOCI_"^"_PRIME_"^"_PRIMI_"^"_UID_"^"_STATUS
  1. ..S ^TMP("PXBVSTG",$J,VSTDTI,IEN)=GROUP
  1. K DIC,DR,DA
  1. ;
  1. ;
  1. B ;--ADD Line Numbers
  1. I $D(^TMP("PXBVSTG",$J)) D
  1. .S PXBCC=PXBC+1,VST="" F S VST=$O(^TMP("PXBVSTG",$J,VST)) Q:VST="" D
  1. ..S IEN=0 F S IEN=$O(^TMP("PXBVSTG",$J,VST,IEN)) Q:IEN="" S PXBCC=PXBCC-1 D
  1. ...S ^TMP("PXBKY",$J,VST,PXBCC)=$G(^TMP("PXBVSTG",$J,VST,IEN))
  1. ...S ^TMP("PXBSAM",$J,PXBCC)=$G(^TMP("PXBVSTG",$J,VST,IEN))
  1. ...S ^TMP("PXBSKY",$J,PXBCC,IEN)=""
  1. ;
  1. F ;--FINISH UP THE VARIABLES
  1. K ^TMP("PXBU",$J),^UTILITY("DIQ1",$J)
  1. S PXBCNT=+$G(PXBC)
  1. D DISP
  1. Q VAL
  1. ;
  1. ;---GO TO PROMPTING
  1. DISP ;--DISPLAY
  1. ;---------------NEW CURSOR CONTROL VARIABLE-----------------------
  1. N IOARM0,IOARM1,IOAWM0,IOAWM1,IOBOFF,IOBON,IOCOMMA,IOCUB,IOCUD,IOCUF
  1. N IOCUON,IOCUOFF,IOCUU,IODCH,IODHLB,IODHLT,IODL,IODWL,IOECH,IOEDALL
  1. N IOEDBOP,IOEDEOP,IOEFLD,IOELALL,IOELBOL,IOELEOL,IOENTER,IOFIND
  1. N IOHDWN,IOHOME,IOHTS,IOHUP,IOICH,IOIL,IOIND,IOINHI,IOINLOW,IOINORM
  1. N IOINSERT,IOKP0,IOKP1,IOKP2,IOKP3,IOKP4,IOKP5,IOKP6,IOKP7,IOKP8,IOKP9
  1. N IOIRM0,IOIRM1,IOKPAM,IOKPNM,IOMC,IOMINUS,IONEL,IONEXTSC,IOPERIOD
  1. N IOPF1,IOPF2,IOPF3,IOPF4,IOPREVSC,IOPROB,IOPTCH10,IOPTCH12,IOPTCH16
  1. N IORC,IOREMOVE,IORESET,IORI,IORVOFF,IORVON,IOSC,IOSGR0,IOSELECT
  1. N IOSTBM,IOSWL,IOTBC,IOTBCALL,IOUOFF,IOUON,IOIS
  1. ;
  1. ;------------------------*******----------------------------------
  1. D TERM^PXBCC
  1. D FIX1^PXBCC
  1. D HDR3^PXBUTL(DFN,1)
  1. D REQ^PXBDREQ(8)
  1. D EN0^PXBDVST
  1. D LOC^PXBCC(15,0)
  1. D WIN17^PXBCC(PXBCNT)
  1. D VST^PXBPVST
  1. D FULL0^PXBCC
  1. D CLEAR1^PXBCC
  1. K ^TMP("PXBKY",$J),^TMP("PXBSAM",$J),^TMP("PXBSKY",$J),^TMP("PXBVSTG",$J),^TMP("PXBU",$J),^TMP("PXBDVST",$J)
  1. ;
  1. ;
  1. Q
  1. ;---END OF PROMPTING