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

TIUVSIT.m

Go to the documentation of this file.
  1. TIUVSIT ; SLC/JER - Interactive Visit look-up;09-Apr-2014 16:23;DU
  1. ;;1.0;TEXT INTEGRATION UTILITIES;**39,91,107,117,179,1007,1010,190,1011,1012**;Jun 20, 1997;Build 45
  1. ;IHS/ITSC/LJF 02/27/2003 added IHS calls
  1. ;IHS/MSC/MGH 02/25/2010 Added mods back after patch 179
  1. ;IHS/MSC/MGH Patch 10 added parameter to MAIN entry point
  1. ENPN(TIUY,DFN,ALLOWNEW) ; Entry point for Progress Notes
  1. N DIRUT,DUOUT,DTOUT,TIULOC,TIUINOUT
  1. I +$G(DFN)'>0 Q
  1. D MAIN(.TIUY,DFN,"","","","",1,"","",$G(ALLOWNEW)) Q ;IHS/ITSC/LJF Display all visits
  1. I +$D(^DPT(DFN,.1)) D MAIN^TIUMOVE(.TIUY,DFN,"","","","1","CURRENT",0) Q
  1. S TIUINOUT=$$INOUT
  1. I $D(DIRUT) Q
  1. I $P(TIUINOUT,U)="o" D MAIN(.TIUY,DFN,"","","","",1,"","",$G(ALLOWNEW)) Q
  1. D MAIN^TIUMOVE(.TIUY,DFN,"","","",1,"LAST",1)
  1. Q
  1. MAIN(TIUY,DFN,TIUSSN,TIUVDT,TIULDT,TIUDFLT,TIUMODE,TIULOC,TIUOCC,LETNEW,TIUCAT) ;Control
  1. N TIUFUTUR
  1. S TIUCAT=$G(TIUCAT)
  1. AGN K ^TMP("TIUVN",$J),^TMP("TIUVDT",$J),^TMP("TIUVNI",$J),^TMP("TIUNOT",$J),^TMP($J,"SDAMA301")
  1. N C,I,N,TIUI,TIUII,TIUDA,TIUER,TIUOK,TIUX,TIUOUT,X,TIUNVIS,VASD,VAERR
  1. N TIUPICK,TIULAST,TIUSDC,TIUVTRY,TIUAPPTS,TIUARR
  1. S TIUMODE=$G(TIUMODE,1),LETNEW=$G(LETNEW,1)
  1. S:+$G(DFN)'>0 DFN=+$$PATIENT^TIULA($G(TIUSSN)) I +DFN'>0 S TIUOUT=1 Q
  1. S TIUOCC=$G(TIUOCC,20)
  1. ;
  1. K BTIUQ D FINDVST^BTIUVSIT Q:$G(BTIUQ) K BTIUQ G IHS1 ;IHS/ITSC/LJF
  1. ;
  1. S TIUARR("FLDS")="1;2"
  1. S TIUARR(1)=2000000,TIUARR(4)=DFN,TIUARR("MAX")=1
  1. S TIUAPPTS=$$SDAPI^SDAMA301(.TIUARR)
  1. K ^TMP($J,"SDAMA301")
  1. I TIUAPPTS=-1 D Q
  1. . W !!,"Could not retrieve patient information due to a problem with the database.",!,"Please contact IRM"
  1. I '$G(TIUAPPTS),(+TIUMODE'>0) Q
  1. ; No appointments
  1. I '$G(TIUAPPTS),(+TIUMODE>0) D I +$G(TIUX)'>0 Q
  1. . W !!,"No SCHEDULED APPOINTMENTS on file"
  1. . D MAIN^TIUVISIT(.TIUY,DFN,$G(TIUSSN),$G(TIUVDT),$G(TIULDT),$G(TIUDFLT),$G(TIUMODE),$G(TIULOC),$G(TIUOCC),$G(LETNEW),"H",1,.TIUFUTUR)
  1. . I +$G(TIUOUT) Q
  1. . I '$D(TIUY),+LETNEW,'+$G(TIUVTRY) D ADD(DFN,.TIUX,1,.TIUSDC)
  1. I '$G(TIUAPPTS),(+TIUX>0) G VADPT
  1. I '$D(^TMP("TIUVN",$J)) D GETAPPT^TIUVSIT1(DFN,$G(TIULOC),$G(TIUOCC),$G(TIULDT),"",.TIULAST,$G(TIUVDT),+$G(TIUFUTUR)) S TIUFUTUR=0
  1. ; error in visit lookup
  1. I +TIUMODE,$D(^TMP("TIUVERR",$J)) D Q
  1. . W !!,$G(^TMP("TIUVERR",$J)),!
  1. . I $D(^TMP("TIUVERR",$J,115)) W ^TMP("TIUVERR",$J,115),!
  1. . K ^TMP("TIUVERR",$J)
  1. ; no appointments scheduled w/in selection range
  1. I +TIUMODE,'$D(^TMP("TIUVN",$J)),+LETNEW D G:+$G(TIUFUTUR) AGN Q:+$G(TIUX)'>0 G VADPT
  1. . N WHATNOW
  1. . W !!,"No SCHEDULED APPOINTMENTS found through "
  1. . W $$DATE^TIULS($$FMADD^XLFDT(DT,1),"AMTH DD, CCYY"),"...",!
  1. . S WHATNOW=$$UP^XLFSTR($E($$NOTFOUND^TIUVSIT1))
  1. . Q:$S(+$G(DUOUT):1,+$G(DTOUT):1,+$G(DIROUT):1,1:0)
  1. . I $E(WHATNOW)="U" D Q
  1. . . D MAIN^TIUVISIT(.TIUY,DFN,$G(TIUSSN),$G(TIUVDT),$G(TIULDT),$G(TIUDFLT),$G(TIUMODE),$G(TIULOC),$G(TIUOCC),$G(LETNEW),"H",1,.TIUFUTUR) Q:+$G(TIUFUTUR)
  1. . . I '$D(TIUY),+LETNEW,'+$G(TIUVTRY) D ADD(DFN,.TIUX,1,.TIUSDC)
  1. . I $E(WHATNOW)="F" S TIUFUTUR=1 Q ; FUTURE
  1. . D ADD(DFN,.TIUX,$S($E(WHATNOW)="N":"",1:1),.TIUSDC)
  1. I '+TIUMODE,'$D(^TMP("TIUVNI",$J)) Q
  1. ;
  1. IHS1 ;IHS/ITSC/LJF 02/27/2003 Added line label
  1. ;
  1. I '+TIUMODE,$G(TIUDFLT)="LAST" D Q:+$G(TIUX)'>0 G VADPT
  1. . N TIUI S TIUI=+$O(^TMP("TIUVNI",$J,0))
  1. . S TIUX=$$GETVSIT(TIUI)
  1. I +TIUMODE,($G(TIUDFLT)="LAST"),(+$O(^TMP("TIUVNI",$J,0))>0) S TIUPICK=+$O(^TMP("TIUVNI",$J,0))
  1. S (TIUER,TIUOK,TIUI)=0
  1. ;W !!,"The following SCHEDULED VISITS are available:",! ;IHS/ITSC/LJF
  1. W !!,"The following VISITS are available:",! ;IHS/ITSC/LJF
  1. F S TIUI=$O(^TMP("TIUVN",$J,TIUI)) Q:+TIUI'>0 D Q:+TIUER!+TIUOK!+$G(TIUX)!+$G(TIUOUT)
  1. . S TIUII=TIUI D WRITE
  1. . I '(TIUI#5) D BREAK I $S($G(X)="U":1,$G(X)["UNS":1,1:0) D Q
  1. . . D MAIN^TIUVISIT(.TIUY,DFN,$G(TIUSSN),$G(TIUVDT),$G(TIULDT),$G(TIUDFLT),$G(TIUMODE),$G(TIULOC),$G(TIUOCC),$G(LETNEW),"H",1,.TIUFUTUR)
  1. . . S TIUOUT=1
  1. . I $G(X)["?" S X="",TIUI=TIUI-5
  1. . I $G(X)["F" S X=""
  1. I +$G(TIUFUTUR),$S(+TIUOK:1,+TIUER:1,$D(TIUY)>9:1,+$G(TIUX):1,1:0) S TIUFUTUR=0
  1. I +$G(TIUFUTUR) S TIUOUT=0 G AGN
  1. G:$D(TIUOUT) CLEAN
  1. G AGN:+TIUER
  1. I +$G(TIUII)#5,+TIUMODE D BREAK I $S($G(X)="U":1,$G(X)["UNS":1,1:0) D G:+$G(TIUFUTUR) AGN Q
  1. . D MAIN^TIUVISIT(.TIUY,DFN,$G(TIUSSN),$G(TIUVDT),$G(TIULDT),$G(TIUDFLT),$G(TIUMODE),$G(TIULOC),$G(TIUOCC),$G(LETNEW),"H",1,.TIUFUTUR)
  1. G:$D(TIUOUT) CLEAN
  1. I $S(+TIUER:1,$G(X)["?":1,$G(X)["F":1,1:0) G AGN
  1. I +TIUOK,'+$G(TIUNVIS) D
  1. . S TIUX=$$GETVSIT(+TIUOK)
  1. . W " ",$$DATE^TIULS(+$P(TIUX,";",2),"AMTH DD CCYY@HR:MIN")
  1. VADPT D PATVADPT^TIULV(.TIUY,DFN,"",$G(TIUX),$G(TIUSDC))
  1. CLEAN K ^TMP("TIUVN",$J),^TMP("TIUVDT",$J),^TMP("TIUVNI",$J),^TMP("TIUNOT",$J)
  1. Q
  1. BREAK ; Handle prompting
  1. I TIUII=1 S (TIUOK,X)=1
  1. W !,"CHOOSE 1-",TIUII,", or",!
  1. ;
  1. ;;IHS/ITSC/LJF 05/08/2003 add choice to view visit
  1. ;W:'(TIUII#20) "<M>ORE VISITS, " W "<U>NSCHEDULED VISITS, "
  1. W:'(TIUII#20) "<M>ORE VISITS, " W "<V>IEW VISITS, "
  1. ;I +$P(TIUPRM0,U,14) W:'+LETNEW " or " W "<F>UTURE VISITS, "
  1. W:+LETNEW "or <N>EW VISIT"
  1. ;W:$D(^TMP("TIUVN",$J,TIUII+1)) !,"<RETURN> TO CONTINUE",!,"OR '^' TO QUIT"
  1. W:$D(^TMP("TIUVN",$J,TIUII+1)) !,"<RETURN> TO CONTINUE or '^' TO QUIT "
  1. ;W ": " W:$D(TIUPICK) $P(^TMP("TIUVN",$J,TIUPICK),U),"// " R X:DTIME
  1. R X:DTIME
  1. ;IHS/ITSC/LJF 05/08/2003 end of mods
  1. ;
  1. S X=$$UP^XLFSTR(X)
  1. I $S('$T:1,X["^":1,1:0) S (TIUER,TIUOUT)=1 Q
  1. S:X=""&$D(TIUPICK) X=TIUPICK
  1. I X?1"V".N D VV^BTIUPCC(X) S TIUI=0 D BREAK Q ;IHS/ITSC/LJF 05/08/2003
  1. I X["?" D HELP^TIUVSITH(X) Q
  1. I $S(X="M":1,X="MORE":1,1:0) D MORE Q
  1. ;I $S(X="F":1,X["FUT":1,1:0) D FUTURE Q ;IHS/ITSC/LJF 05/08/2003
  1. ;I $S(X="U":1,X["UNS":1,1:0) Q ;IHS/ITSC/LJF 05/08/2003
  1. I +LETNEW'>0,(X=""),'$D(^TMP("TIUVN",$J,TIUII+1)) S (TIUER,TIUOUT)=1 Q
  1. ;I +LETNEW,$S(X="N":1,X="NEW":1,X=""&'$D(^TMP("TIUVN",$J,TIUII+1)):1,1:0) D ADD(DFN,.TIUX,$S(X="N":0,X="NEW":0,1:1),.TIUSDC) I +$G(TIUX)'>0 S (TIUER,TIUOUT)=1 Q ;IHS/ITSC/LJF 02/27/2003
  1. I +LETNEW,$S(X="N":1,X="NEW":1,X=""&'$D(^TMP("TIUVN",$J,TIUII+1)):1,1:0) D ADD(DFN,.TIUX,$S(X="N":0,X="NEW":0,1:1),.TIUSDC) I +$G(TIUER) S TIUOUT=1 Q ;IHS/ITSC/LJF 02/27/2003 change quit logic
  1. I $S(X="":1,X="N":1,X="NEW":1,1:0) Q
  1. I X'=+X!'$D(^TMP("TIUVN",$J,+X)) W !!,$C(7),"INVALID RESPONSE",! G BREAK
  1. S TIUOK=X
  1. Q
  1. INOUT() ; Ask INPATIENT/OUTPATIENT
  1. N TIUPRMT S TIUPRMT="Is this note for INPATIENT or OUTPATIENT care? "
  1. W:'$D(^DPT(DFN,.1)) !!,"This patient is not currently admitted to the facility...",!
  1. Q $$READ^TIUU("SA^i:INPATIENT;o:OUTPATIENT",TIUPRMT,"OUTPATIENT")
  1. MORE ; Modify date range, list more visits
  1. N TIUI,TIUCNT
  1. S TIUI=+$O(^TMP("TIUVDT",$J,0)),TIUCNT=+$G(^TMP("TIUVDT",$J,+TIUI))
  1. D GETAPPT^TIUVSIT1(DFN,$G(TIULOC),$G(TIUOCC),TIUI,TIUCNT,.TIULAST)
  1. Q
  1. FUTURE ; Get future appointments
  1. D GETAPPT^TIUVSIT1(DFN,$G(TIULOC),$G(TIUOCC),$G(TIULDT),"",.TIULAST,$G(TIUVDT),1)
  1. I $D(^TMP("TIUVERR",$J)) D
  1. . W !!,$G(^TMP("TIUVERR",$J)),!
  1. . I $D(^TMP("TIUVERR",$J,115)) W ^TMP("TIUVERR",$J,115),!
  1. I $P(+$G(^TMP("TIUVNI",$J,1)),".")'>+$$NOW^XLFDT D
  1. . W !!,"No Future Appointments found...",!
  1. E I $P(+$G(^TMP("TIUVNI",$J,1)),".")'>$$FMADD^XLFDT(DT,1) D
  1. . W !!,"No Appointments found more than one day in future..."
  1. S TIUI=0,TIUFUTUR=1
  1. Q
  1. GETVSIT(TIUOK) ; Get associated visit
  1. S BTIUVSIT=$G(^TMP("TIUIHSV",$J,TIUOK)) ;IHS/ITSC/LJF 02/27/2003 set IHS visit variable
  1. N APPT,TIUVSIT,VLOC,VSTOP,VDT,VTYPE
  1. S APPT=$G(^TMP("TIUVNI",$J,+TIUOK))
  1. S VDT=+APPT,VLOC=$P(APPT,U,2)
  1. S VSTOP=$P($G(^SC(+VLOC,0)),U,7)
  1. ;S VTYPE=$S($P(APPT,U,3)="I":"I",1:"A") ;IHS/ITSC/LJF 02/27/2003
  1. S VTYPE=$P(APPT,U,3) ;IHS/ITSC/LJF 02/27/2003
  1. S TIUVSIT=VLOC_";"_VDT_";"_VTYPE
  1. Q TIUVSIT
  1. ADD(DFN,VSTR,ASK,VSTOP) ; Add a visit for patient
  1. N VTYPE,VDT,VLOC,TIUY,DA,DIE,DR,TIUAPDT,X,Y W !
  1. S ASK=$G(ASK,1)
  1. I +ASK D
  1. . W !,$C(7),$C(7),"Patient & Visit are Required...",!
  1. . S TIUY=$$READ^TIUU("YAO","Do you wish to add a NEW Visit? ","NO")
  1. I +ASK,(+TIUY'>0) S TIUX=0,TIUER=1 Q
  1. ;
  1. D ADD^BTIUVSIT($G(DFN),"",$G(TIUSDC)) Q ;IHS/ITSC/LJF 02/27/2003 use IHS code to add visit, then quit
  1. ;
  1. I $G(VLOC)']"" S VLOC=$$SELLOC
  1. I +VLOC'>0 S TIUER=1 Q
  1. S VSTOP=+$P(^SC(+VLOC,0),U,7)
  1. S VDT=+$$READ^TIUU("D^:NOW:ERSX","Enter Visit Date/Time","NOW","Precise Date & Time are Required")
  1. I +VDT'>0 S TIUER=1 Q
  1. S TIUAPDT=+$O(^TMP("TIUNOT",$J,+VLOC,+$P(VDT,".")))
  1. I +TIUAPDT>0,(+$P(TIUAPDT,".")=+$P(VDT,".")) D Q
  1. . W !!,$C(7)," Item #",+$G(^TMP("TIUNOT",$J,+VLOC,+TIUAPDT))
  1. . W " is scheduled for ",$$DATE^TIULS(TIUAPDT,"MM/DD/YY HR:MIN")
  1. . W " at this location..."
  1. . W !!,"Please select the existing appointment, rather than creating a "
  1. . W "redundant one.",!
  1. . S TIUER=1
  1. S VTYPE=$$VSITYPE(VSTOP)
  1. S VSTR=+VLOC_";"_+VDT_";"_VTYPE
  1. I +VSTR'>0 S TIUER=1 Q
  1. S TIUNVIS=+VDT,TIUER=0
  1. Q
  1. WRITE ; Writes each list element
  1. N TIUX S TIUX=^TMP("TIUVN",$J,TIUI)
  1. W !,$J(TIUII,4),"> ",$P(TIUX,U),?27,$E($P(TIUX,U,3),1,21),?50,$P(TIUX,U,2)
  1. Q
  1. SELLOC() ; Select Hospital Location
  1. N DIC,X,Y,TIUAPDT S DIC=44,DIC(0)="AEMQ"
  1. S DIC("A")="PATIENT LOCATION: "
  1. S DIC("B")=$P($$PERSLOC^TIULE(DUZ),U,2)
  1. S:DIC("B")']"" DIC("B")=$P($G(^SC(+$G(^DISV(DUZ,"^SC(")),0)),U)
  1. S DIC("S")="I $$GOODLOC^TIUPREF(Y)"
  1. D ^DIC K DIC("S")
  1. Q Y
  1. DEFER(DA,TIUSDC) ; Mark record for deferred crediting of stop code
  1. N DIE,DR,X,Y,TIUVSIT
  1. I +$G(TIUSDC)'>0 Q
  1. S DIE=8925
  1. S:$$WORKOK^TIUPXAP1(+DA) DR=".11////1;"
  1. S DR=$G(DR)_"1206////^S X="_+TIUSDC
  1. D ^DIE
  1. ;If not called via the broker try to link document to an existing visit
  1. I '$$BROKER^XWBLIB,$$LNKVST^TIUPXAP3(+DA,.TIUVSIT)
  1. Q
  1. CREDIT(TIUDA) ; Call EN3^SDACS to Credit Stop Code
  1. N DA,DFN,VSIT,TIU,TIUD0,TIUDPRM
  1. S TIUD0=$G(^TIU(8925,+TIUDA,0))
  1. I TIUD0']"" Q
  1. D DOCPRM^TIULC1(+TIUD0,.TIUDPRM)
  1. ; If SUPPRESS DX/CPT ON NEW VISIT is set to YES, then Quit
  1. I +$P($G(TIUDPRM(0)),U,14)>0 Q
  1. S DFN=+$P(TIUD0,U,2),VSIT=$P(TIUD0,U,3)
  1. D GETTIU^TIULD(.TIU,TIUDA)
  1. D CREDIT^TIUPXAPI(DFN,.TIU,VSIT)
  1. Q
  1. REMFLAG(DA) ; Remove credit flag from TIU Document Record
  1. N DIE,DR,X,Y
  1. S DIE=8925,DR=".11///@" D ^DIE
  1. Q
  1. VSITYPE(VSTOP) ; Call reader to get VISIT TYPE
  1. N DFLT,PROMPT,X,Y S VSTOP=$P($G(^DIC(40.7,+$G(VSTOP),0)),U)
  1. S DFLT=$S(VSTOP["TELE":"TELEPHONE",1:"AMBULATORY")
  1. S PROMPT="TYPE OF VISIT: "
  1. S X="SMA^a:AMBULATORY (WALK-IN);t:TELEPHONE;i:IN HOSPITAL;e:EVENT (HISTORICAL)"
  1. S Y=$$READ^TIUU(X,PROMPT,DFLT) W " ",$P(Y,U,2),!
  1. S Y=$$UP^XLFSTR($P(Y,U))
  1. Q Y
  1. GETAPPT(DFN,CLINIC,OCCLIM,INDEX,COUNT,LAST,EARLY,FUTURE) ; Get list
  1. D GETAPPT^TIUVSIT1($G(DFN),$G(CLINIC),$G(OCCLIM),$G(INDEX),$G(COUNT),$G(LAST),$G(EARLY),$G(FUTURE))
  1. Q