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

TIULA.m

Go to the documentation of this file.
  1. TIULA ; SLC/JER - Interactive Library functions ;04/23/10 09:00
  1. ;;1.0;TEXT INTEGRATION UTILITIES;**79,113,250**;Jun 20, 1997;Build 14
  1. ;
  1. ; ICR #10142 - EN^DDIOL Routine
  1. ; #10006 - DIC Routine & DIC, X, & Y local vars
  1. ; #10026 - DIR Routine & DIR, X, & Y local vars
  1. ; #10112 - $$PRIM^VASITE, $$SITE^VASITE Routines
  1. ; #664 - DIVISION^VAUTOMA Routine & VAUTD local var
  1. ; #10140 - XQORM, EN^XQORM Routine & XQORM local var
  1. ;
  1. PATIENT(TIUSSN) ; Select a patient
  1. N X,DIC,Y S:$G(TIUSSN)]"" X=TIUSSN
  1. S DIC=2,DIC(0)=$S($G(TIUSSN)']"":"AEMQ",1:"MX") D ^DIC
  1. Q Y
  1. SELDIV ; Get document division(s)
  1. ;
  1. ; Output - SELDIV -1= user ^ at prompt if multidivisional
  1. ; 0= institution file pointer missing for
  1. ; division entry
  1. ; 1= successful division selection
  1. ; BADDIV = comma-delimited list of bad divisions (if any)
  1. ; TIUDI( undefined= user <cr> for all divisions or ^ at prompt
  1. ; if multidivisional
  1. ; defined= user selected one or more divisions if
  1. ; multidivisional, or pre-selection of
  1. ; division file entry if not multidivisional;
  1. ; i.e.: TIUDI(file #40.8 ien)= Institution
  1. ; file pointer for file #40.8 entry
  1. N TIUI,VAUTD,Y
  1. K SELDIV,TIUDI,BADDIV
  1. ; -- Determine if facility is multidivisional
  1. I $P($G(^DG(43,1,"GL")),U,2) D
  1. . D DIVISION^VAUTOMA
  1. . I Y<0 S SELDIV=-1 Q
  1. . I VAUTD=1 S SELDIV=1 Q
  1. . S TIUI=0 F S TIUI=$O(VAUTD(TIUI)) Q:'TIUI D ONE(TIUI,.VAUTD)
  1. E D
  1. . S TIUI=$$PRIM^VASITE D ONE(TIUI,.VAUTD)
  1. Q
  1. ONE(TIUI,VAUTD) ; Input - TIUI Medical Center Division file (#40.8) IEN
  1. N TIUIFP
  1. S TIUIFP=$P($$SITE^VASITE(,TIUI),U) I TIUIFP>0 D
  1. . S TIUDI(TIUI)=TIUIFP,SELDIV=1
  1. E D
  1. . S SELDIV=0,BADDIV=$G(BADDIV)_$S($L($G(BADDIV)):", ",1:"")_$G(VAUTD(TIUI))
  1. Q
  1. ;
  1. SELSVC(TIUSVCS) ;Select Services
  1. ; Input -- None
  1. ; Output -- 1=Successful and 0=Failure
  1. ; TIUSVCS Service Selection Array
  1. N TIUCNT,TIUSVCI,Y
  1. S TIUCNT=0
  1. F Q:'$$ASKSVC(.TIUSVCS,TIUCNT,.TIUSVCI) D
  1. . S TIUSVCS(+TIUSVCI)=""
  1. . S TIUCNT=TIUCNT+1
  1. . S TIUSVCI=""
  1. I $G(TIUSVCI)=-1 S Y=0 G SELSVCQ
  1. I $G(TIUSVCI)="ALL" S TIUSVCS="ALL"
  1. S Y=1
  1. SELSVCQ Q +$G(Y)
  1. ;
  1. ASKSVC(TIUSVCS,TIUCNT,TIUSVCI) ;Ask Service
  1. ; Input -- TIUSVCS Service Selection Array
  1. ; TIUCNT Number of Services Selected
  1. ; Output -- 1=Successful and 0=Failure
  1. ; TIUSVCI Service/Section file (#49) IEN
  1. N DIR,DTOUT,DUOUT,X,Y
  1. S DIR(0)="PAO^49:AEMQ^K:'$$CHKSVC^TIULA(.TIUSVCS,+Y) X"
  1. S DIR("PRE")="I X="""",'$G(TIUCNT),'$D(DTOUT) S TIUSVCI=""ALL"""
  1. S DIR("A")="Select "_$S($G(TIUCNT):"another ",1:"")_"service: "_$S('$G(TIUCNT):"ALL// ",1:"")
  1. I '$G(TIUCNT) S DIR("?")=" OR enter Return for ALL services." W !
  1. D ^DIR
  1. I Y>0 S TIUSVCI=+Y
  1. I $D(DTOUT)!($D(DUOUT)) S TIUSVCI=-1
  1. Q $S($G(TIUSVCI)>0:1,1:0)
  1. ;
  1. CHKSVC(TIUSVCS,TIUSVCI) ;Check Selected Service
  1. ; Input -- TIUSVCS Service Selection Array
  1. ; TIUSVCI Service file (#49) IEN
  1. ; Output -- 1=Successful and 0=Failure
  1. N Y
  1. S Y=1
  1. ;Check if Service has already been selected
  1. I $D(TIUSVCS(TIUSVCI)) D EN^DDIOL("This Service has already been selected.","","!?5") S Y=0
  1. Q +$G(Y)
  1. ;
  1. SELSTAT(Y,PARM,DEF) ; Select Signature status
  1. N I,XQORM,X,TIUY
  1. S XQORM=+$O(^ORD(101,"B","TIU STATUS MENU",0))_";ORD(101,"
  1. I +XQORM'>0 W !,"Status selection unavailable." S TIUY=-1 G STATX
  1. S XQORM(0)=$G(PARM),XQORM("A")="Select Status: "
  1. I $S(PARM="F":1,PARM="R":1,1:0) S X=DEF
  1. S XQORM("B")=DEF D ^XQORM
  1. S TIUY=$G(Y)
  1. I +$G(Y)=1,(+$G(Y(1))=7) S Y=2,Y(2)="8^4843^amended^8"
  1. STATX Q TIUY
  1. SELSCRN(DEF) ; Select Review Screen
  1. N DIC,XQORM,X,Y
  1. S DIC=101,DIC(0)="X",X="TIU REVIEW SCREEN MENU" D ^DIC
  1. I +Y>0 D
  1. . S XQORM=+Y_";ORD(101,",XQORM(0)="1A",XQORM("A")="Select Category: "
  1. . S XQORM("S")="I 1 X:$D(^ORD(101,+$P(^ORD(101,DA(1),10,DA,0),U),24)) ^(24)"
  1. . S XQORM("B")=DEF D ^XQORM
  1. . I +Y,($D(Y)>9) D
  1. . . S Y=$S(Y(1)["Author":"AAU",Y(1)["Patient":"APT",Y(1)["Spec":"ATS",Y(1)["Transcrip":"ATC",Y(1)["All":"ALL",Y(1)["Subject":"ASUB",Y(1)["Service":"ASVC",Y(1)["Location":"ALOC",1:"")
  1. . . I +$G(Y(1))'>0,(X'="^^"),(X'="^") D Q
  1. . . . W !,"^^-jumps not allowed from this prompt." S Y=-1
  1. . . S:Y'="ALL" Y=Y_U_$$SELPAR(Y)
  1. . . S:Y="ALL" Y=Y_U_"ANY"
  1. Q Y
  1. SELPAR(DEF) ; Select an author or patient or...
  1. N DIC,X,Y
  1. I DEF="ASUB" S Y=$$ASKSUBJ^TIULA1 G SELPARX
  1. S DIC=$S(DEF="APT":2,DEF="ATS":45.7,DEF="ASVC":123.5,1:200)
  1. S DIC(0)="AEMQ"
  1. S DIC("A")="Select "_$S(DEF="APT":"PATIENT",DEF="AAU":"AUTHOR",DEF="ATS":"TREATING SPECIALTY",DEF="ATC":"TRANSCRIPTIONIST",DEF="ASVC":"SERVICE",1:"ATTENDING PHYSICIAN")_": "
  1. I DEF="ARP" S DIC("S")="I $$ISA^USRLA(+$G(Y),""PROVIDER"")"
  1. D ^DIC K DIC("S") I +Y>0 D
  1. . I $S(DEF="APT"&'$D(^TIU(8925,"C",+Y)):1,DEF="AAU"&'$D(^TIU(8925,"CA",+Y)):1,DEF="ARP"&'$D(^TIU(8925,"CR",+Y)):1,1:0) W !,"No entries for ",$P(Y,U,2) S Y=0
  1. SELPARX Q Y
  1. EDATE(PRMPT,STATUS,DFLT) ; Get early date
  1. N X,Y,TIUPRMT,TIUDFLT
  1. I $G(STATUS)=4 S Y=1 Q Y
  1. S TIUPRMT=" Start "_$S($L($G(PRMPT)):PRMPT_" ",1:"")_"Date [Time]: "
  1. S TIUDFLT=$S($L($G(DFLT)):DFLT,1:"T-30")
  1. S Y=$$READ^TIUU("DOA^::AET",TIUPRMT,TIUDFLT)
  1. Q Y
  1. LDATE(PRMPT,STATUS,DFLT) ; Get late date
  1. N X,Y,TIUPRMT,TIUDFLT
  1. I $G(STATUS)=4 S Y=9999999 Q Y
  1. S TIUPRMT="Ending "_$S($L($G(PRMPT)):PRMPT_" ",1:"")_"Date [Time]: "
  1. S TIUDFLT=$S($L($G(DFLT)):DFLT,1:"NOW")
  1. S Y=$$READ^TIUU("DOA^::AET",TIUPRMT,TIUDFLT)
  1. Q Y
  1. CATEGORY() ; Select Service Category
  1. N DIR,X,Y
  1. S DIR(0)="9000010,.07",DIR("A")="Select SERVICE CATEGORY"
  1. D ^DIR
  1. Q Y_U_Y(0)
  1. SELTYP(DA,RETURN,PARM,DFLT,TYPE,MODE,DCLASS,PICK) ; Select Document Types
  1. N I,J,X,XQORM,CURTYP,Y
  1. I '$D(RETURN) S RETURN=$NA(^TMP("TIUTYP",$J)) K @RETURN
  1. ; TIUK is STATIC
  1. ;I +MODE D DOCLIST^TIULA1(DA,.RETURN,PARM,DFLT) Q:+RETURN'<0
  1. ; *** ADD CALL TO PERSONAL DOCUMENT LISTER HERE
  1. N:'$D(TIUK) TIUK S TIUK=+$G(TIUK)
  1. I $G(DFLT)="LAST" D
  1. . S DFLT=$O(^DISV(DUZ,"XQORM",DA_";TIU(8925.1,",0))
  1. . S DFLT=$S(+DFLT:$G(^DISV(DUZ,"XQORM",DA_";TIU(8925.1,",DFLT)),1:"")
  1. I $G(TYPE)']"" S TYPE="DOC"
  1. I $G(MODE)']"" S MODE=1 ; Default is ASK
  1. S XQORM=DA_";TIU(8925.1,",XQORM(0)=$S(+$P($G(^TIU(8925.1,+DA,10,0)),U,3)=1:"F",1:$G(PARM,"AD"))
  1. I XQORM(0)["D" S XQORM("H")="W !!,$$CENTER^TIULS(""--- ""_$P(^TIU(8925.1,+DA,0),U,3)_"" ---""),!"
  1. I $S(XQORM(0)="F":1,XQORM(0)="R":1,1:0) S X=$S(DFLT]"":DFLT,1:"ALL")
  1. S:$G(DFLT)]"" XQORM("B")=DFLT
  1. S XQORM("A")="Select "_$S(XQORM(0)["D":"Document",1:$P(^TIU(8925.1,+DA,0),U,3))_$S($P(^TIU(8925.1,+DA,0),U,4)="DOC":" Component",1:" Type")_$S(+XQORM(0)'=1:"(s)",1:"")_": "
  1. ; If screening inactive titles proves to be correct, remove comment
  1. ; from the line below:
  1. ; S XQORM("S")="I +$$CANPICK^TIULP(+$G(^TIU(8925.1,+DA(1),10,+DA,0)))>0"
  1. D EN^XQORM
  1. I +Y'>0,($D(@RETURN)'>9) S @RETURN=Y Q
  1. I (PARM["A"),(+$G(@RETURN)'>0) M PICK=Y
  1. S I=0 F S I=$O(Y(I)) Q:+I'>0 D
  1. . N TYPMATCH
  1. . S J=+$P(Y(I),U,2),CURTYP=$P($G(^TIU(8925.1,+J,0)),U,4)
  1. . I CURTYP="DC" S DCLASS=+$G(DCLASS)+1,DCLASS(DCLASS)=J
  1. . I I TYPE="DOC",(PARM["A"),(+$O(^TIU(8925.1,+J,10,0))'>0) W !!,"The Document Class ",$P(^TIU(8925.1,+J,0),U)," has no active titles at present..."
  1. . S TYPMATCH=$$TYPMATCH^TIULA1(TYPE,CURTYP)
  1. . I +TYPMATCH>0 D
  1. . . S TIUK=+$G(TIUK)+1,@RETURN@(TIUK)=Y(I),@RETURN=TIUK
  1. . I $S('+$G(TYPMATCH):1,CURTYP="CL":1,1:0),+$O(^TIU(8925.1,+J,10,0))>0 D SELTYP(+J,.RETURN,$S(MODE=1:$G(PARM),1:"F"),$S(MODE=1:"LAST",1:"ALL"),TYPE,MODE,.DCLASS,.PICK)
  1. Q