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

TIUSRVP1.m

Go to the documentation of this file.
TIUSRVP1 ; SLC/JER - More API's in support of PUT ;11-Sep-2012 13:00;DU
 ;;1.0;TEXT INTEGRATION UTILITIES;**19,59,89,100,109,167,113,112,1009,219,1010**;Jun 20, 1997;Build 24
 ;Updated for event type
SITEPARM(TIUY) ; Get site parameters for GUI
 N TIUPRM0,TIUPRM1
 D SETPARM^TIULE
 S TIUY=TIUPRM0
 Q
DEFDOC(TIUY,HLOC,USER,TIUDT,TIUIEN) ; Get default primary provider
 N TIUSPRM,TIUDDOC,TIUAUTH
 D SITEPARM(.TIUSPRM)
 S TIUDDOC=+$P(TIUSPRM,U,8)
 S TIUAUTH=$S((+$G(USER)!('+$G(TIUIEN))):0,1:+$P($G(^TIU(8925,+$G(TIUIEN),12)),U,2))
 S USER=$S(+$G(USER):+$G(USER),+$G(TIUAUTH):+$G(TIUAUTH),1:DUZ)
 S TIUDT=$S(+$G(TIUDT):+$G(TIUDT),1:DT)
 S TIUY=$S(TIUDDOC=1:$$DFLTDOC^TIUPXAPI(HLOC),TIUDDOC=2:$$CURDOC(USER),1:"0^")
 Q
CURDOC(USER,TIUDT) ; Is the current user a known Provider?
 N TIUY,TIUPROV S TIUY="0^"
 S USER=$S(+$G(USER):+$G(USER),1:DUZ)
 S TIUDT=$S(+$G(TIUDT):+$G(TIUDT),1:DT)
 S TIUPROV=$$PROVIDER^TIUPXAP1(USER,TIUDT)
 I +TIUPROV S TIUY=USER_U_$$PERSNAME^TIULC1(USER)
 Q TIUY
ISAPROV(TIUY,USER,DATE) ; Is user a provider?
 ; Checks USR CLASS PROVIDER AND 200 Person Class
 ; DATE must not include time (for ISA^USRLM)
 S USER=$G(USER,DUZ)
 S DATE=$G(DATE,DT)
 S TIUY=$$PROVIDER^TIUPXAP1(USER,DATE)
 Q
USRPROV(TIUY,USER,DATE) ; Is USER a USR CLASS provider?
 ; Checks USR CLASS PROVIDER only
 ; DATE must not include time
 N TIUERR
 S USER=$G(USER,DUZ)
 S DATE=$G(DATE,DT),TIUY=0
 I +$$ISA^USRLM(USER,"PROVIDER",.TIUERR,DATE) S TIUY=1 ;  DBIA/ICR 2324
 Q
DOCPARM(TIUY,TIUDA,TIUTYP) ; Get document parameters for GUI
 I '+$G(TIUTYP),+$G(TIUDA) S TIUTYP=+$G(^TIU(8925,+TIUDA,0))
 I '+$G(TIUTYP) S TIUY(0)="" Q
 D DOCPRM^TIULC1(TIUTYP,.TIUY,$G(TIUDA))
 I '$D(TIUY) S TIUY(0)=""
 Q
CONSTUB(TIUDA,GMRCVP,DFN) ; Create a stub for a Consult Report
 N DIE,DR,DA
 D STUB(.TIUDA,"CONSULT REPORT",DFN)
 I +TIUDA'>0 Q
 S DIE=8925,DA=+TIUDA,DR="1405////^S X=GMRCVP"
 D ^DIE
 Q
STUB(TIUDA,TIUTITL,DFN) ; Create a stub
 N TIUVSIT,TIUFPRIV,DIC,DIE,DR,DA,DLAYGO,X,Y S TIUFPRIV=1
 I +$G(TIUTITL)'>0 S TIUTITL=$$WHATITLE^TIUPUTU(TIUTITL)
 I +TIUTITL'>0 S TIUDA=-1 Q
 S (DIC,DLAYGO)=8925,DIC(0)="LF"
 S X=""""_"`"_+TIUTITL_""""
 D ^DIC S TIUDA=+Y Q:+Y'>0
 D EVENT(.TIU,DFN) I $L($G(TIU("VSTR")))'>0 S TIUDA=-1 Q
 S DIE=DIC,DA=TIUDA
 S DR=".02////"_+DFN_";.03////"_$P($G(TIU("VISIT")),U)_";.04////"_+$$DOCCLASS^TIULC1(TIUTITL)_";.05///UNDICTATED;.13////E;1301////"_+$$NOW^XLFDT
 D ^DIE
 Q
EVENT(TIUY,DFN) ; Create an Event-type Visit Entry
 ;IHS/MSC/MGH This call was modified to use the IHS visit
 ;creation for a historical entry Patch 1009
 ;N VDT,VSTR,DGPM
 N DGPM,VIEN
 S DGPM=$G(^DPT(DFN,.105)) ;DBIA/ICR 10035
 ;I +DGPM'>0 D
 ;. S VDT=$$NOW^XLFDT
 ;. S VSTR=";"_VDT_";"_"E"
 D PATVADPT^TIULV(.TIUY,+DFN,DGPM,$G(VSTR))
 S TIUY("LOC")=VLOC_U_$P($G(^SC(VLOC,0)),U,1)
 I $G(TIUY("LOC"))="",+DUZ D
 .N TIUPREF,IDX
 .S TIUPREF=$$PERSPRF^TIULE(DUZ)
 .S IDX=+$P(TIUPREF,U,2)
 .I IDX S TIUY("LOC")=IDX_U_$P($G(^SC(IDX,0)),U,1) ; DBIA/ICR 10040
 S VIEN=$$FNDVIS^BEHOENCX(DFN,VDT,"E",VLOC,-1,,"")
 I +VIEN S TIU("VISIT")=VIEN
 Q
GETPNAME(TIUY,TIUTYPE) ; Get Print Name of a Document
 S TIUY=$$PNAME^TIULC1(TIUTYPE)
 Q
SAVED(TIUY,TIUDA) ; Was the document committed to the database?
 N TIUD12,TIUD13,TIUEBY,TIUAUT,TIUECS S TIUY=1
 S TIUD12=$G(^TIU(8925,TIUDA,12)),TIUD13=$G(^(13))
 S TIUEBY=$P(TIUD13,U,2),TIUAUT=$P(TIUD12,U,2),TIUECS=$P(TIUD12,U,8)
 I $D(^TIU(8925,"ASAVE",+DUZ,TIUDA)) D  Q
 . S TIUY="0^You appear to have been disconnected..."
 I DUZ'=TIUEBY,(TIUEBY'=TIUAUT),$D(^TIU(8925,"ASAVE",+TIUEBY,TIUDA)) D  Q
 . S TIUY="0^The transcriber appears to have been disconnected..."
 I DUZ'=TIUAUT,$D(^TIU(8925,"ASAVE",+TIUAUT,TIUDA)) D  Q
 . S TIUY="0^The author appears to have been disconnected..."
 I DUZ'=TIUECS,$D(^TIU(8925,"ASAVE",+TIUECS,TIUDA)) D  Q
 . S TIUY="0^The expected cosigner appears to have been disconnected..."
 Q
STUFREC(TIUDA,TIUREC,DFN,PARENT,TITLE,TIU) ; load TIUREC for create
 N TIUREQCS,TIUSCAT,TIUSTAT,TIUCPF
 ;Set a flag to indicate whether or not a Title is a member of the
 ;Clinical Procedures Class (1=Yes and 0=No)
 S TIUCPF=+$$ISA^TIULX(TITLE,+$$CLASS^TIUCP)
 S TIUSTAT=$$STATUS(TIUDA,+$G(SUPPRESS),$G(TITLE))
 D REQCOS^TIUSRVA(.TIUREQCS,+TITLE,"",$S(+$G(TIUREC(1202)):+$G(TIUREC(1202)),1:DUZ))
 I +$G(PARENT)'>0 D
 . S TIUREC(.02)=$G(DFN),TIUREC(.03)=$P($G(TIU("VISIT")),U)
 . S TIUREC(.05)=$S(+$G(TIUREC(.05)):+$G(TIUREC(.05)),+TIUSTAT:TIUSTAT,1:5)
 . S TIUREC(.07)=$P($G(TIU("EDT")),U),TIUREC(.08)=$P($G(TIU("LDT")),U)
 . S TIUREC(1401)=$P($G(TIU("AD#")),U)
 . S TIUREC(1402)=$P($G(TIU("TS")),U)
 . S TIUREC(1404)=$P($G(TIU("SVC")),U)
 I +$G(PARENT)>0 D
 . S TIUREC(.02)=+$P($G(^TIU(8925,+PARENT,0)),U,2)
 . S TIUREC(.03)=+$P($G(^TIU(8925,+PARENT,0)),U,3)
 . S TIUREC(.05)=$S(+$G(TIUREC(.05)):+$G(TIUREC(.05)),+TIUSTAT:TIUSTAT,1:5)
 . S TIUREC(.06)=PARENT,TIUREC(.07)=$P(TIU("EDT"),U)
 . S TIUREC(.08)=$P(TIU("LDT"),U)
 . S TIUREC(1401)=$P($G(^TIU(8925,+PARENT,14)),U)
 . S TIUREC(1402)=$P($G(^TIU(8925,+PARENT,14)),U,2)
 . S TIUREC(1404)=$P($G(^TIU(8925,+PARENT,14)),U,4)
 . S TIUREC(1405)=$P($G(^TIU(8925,+PARENT,14)),U,5)
 S TIUREC(.04)=$$DOCCLASS^TIULC1(TITLE)
 S TIUSCAT=$S(+$L($P($G(TIU("CAT")),U)):$P($G(TIU("CAT")),U),+$L($P($G(TIU("VSTR")),";",3)):$P($G(TIU("VSTR")),";",3),1:"")
 S TIUREC(.13)=TIUSCAT
 ;If the document is a member of the Clinical Procedures Class, set the
 ;Author/Dictator and the Expected Signer fields to Null
 S (TIUREC(1202),TIUREC(1204))=$S(+$G(TIUREC(1202)):+$G(TIUREC(1202)),TIUCPF:"",1:+$G(DUZ))
 S TIUREC(1212)=$P($G(TIU("INST")),U)
 S TIUREC(1205)=$P($G(TIU("LOC")),U)
 S TIUREC(1211)=$P($G(TIU("VLOC")),U)
 S TIUREC(1201)=$$NOW^XLFDT
 S TIUREC(1301)=$S($G(TIUREC(1301))]"":$P(TIUREC(1301),U),1:$$NOW^XLFDT)
 I +$$ISDS^TIULX(TITLE) D
 . I +$G(TIU("LDT"))'>0 S TIUREC(.12)=1
 . S TIUREC(.13)="H"
 . D REFDT(.TIUREC)
 ;If the document is a member of the Clinical Procedures Class, set the
 ;Entered By field to Null
 S TIUREC(1303)="R",TIUREC(1302)=$S(TIUCPF:"",1:$G(DUZ))
 I $S(+$G(TIUREC(1208))&(+$G(TIUREC(1204))'=+$G(TIUREC(1208))):1,+$G(TIUREQCS):1,1:0) S TIUREC(1506)=1
 Q
REFDT(TIUX) ; Hack Ref Date/time for DS's
 S TIUX(1301)=$S(+$G(TIU("LDT")):+$G(TIU("LDT")),1:$G(TIUX(1301)))
 Q
STATUS(TIUDA,SUPPRESS,TITLE) ; Compute the status of the current record
 N TIUDPRM,TIUY
 ; If the document is an addendum, compute status based on processing
 ; requirements of the Parent document or its ancestors
 I +$$ISADDNDM^TIULC1(TIUDA) D
 . S TIUDA=$S(+$P(^TIU(8925,TIUDA,0),U,6):$P(^(0),U,6),1:TIUDA)
 . S TITLE=+$G(^TIU(8925,TIUDA,0))
 D DOCPRM^TIULC1(TITLE,.TIUDPRM,$G(TIUDA))
 I +$P(TIUDPRM(0),U,2),+$G(SUPPRESS) S TIUY=3 G STATUX
 S TIUY=$S(+$$REQVER^TIULC(+TIUDA,+$P($G(TIUDPRM(0)),U,3)):4,1:5)
STATUX Q TIUY
IDATTCH(TIUY,TIUDA,TIUDAD) ; Attach TIUDA as ID Child entry to TIUDAD
 N TIUX
 S TIUX(2101)=TIUDAD
 D FILE^TIUSRVP(.TIUY,TIUDA,.TIUX,1)
 D AUDLINK^TIUGR1(TIUDA,"a",TIUDAD)
 D SENDID^TIUALRT1(TIUDA)
 Q
IDDTCH(TIUY,TIUDA) ; Detach TIUDA from its ID Parent
 N TIUX,IDDAD
 I '+$G(^TIU(8925,TIUDA,21)) D  Q
 . S TIUY="0^Record #"_TIUDA_" is NOT an ID Entry."
 S IDDAD=+$G(^TIU(8925,TIUDA,21))
 S TIUX(2101)="@"
 D FILE^TIUSRVP(.TIUY,TIUDA,.TIUX,1)
 D AUDLINK^TIUGR1(TIUDA,"d",IDDAD)
 D IDDEL^TIUALRT1(TIUDA)
 Q
CANDEL(TIUDA) ; Boolean function to evaluate delete request
 Q $S($P(^TIU(8925,TIUDA,0),U,5)>3:0,'+$$EMPTYDOC^TIULF(TIUDA):0,1:1)