TIUSRVP1 ; SLC/JER - More API's in support of PUT ;11/01/03 ;;1.0;TEXT INTEGRATION UTILITIES;**19,59,89,100,109,167,113,112**;Jun 20, 1997 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? S USER=$G(USER,DUZ) S DATE=$G(DATE,DT) S TIUY=$$PROVIDER^TIUPXAP1(USER,DATE) 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 N VDT,VSTR,DGPM S DGPM=$G(^DPT(DFN,.105)) I +DGPM'>0 D . S VDT=$$NOW^XLFDT . S VSTR=";"_VDT_";"_"E" D PATVADPT^TIULV(.TIUY,+DFN,DGPM,$G(VSTR)) 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) 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)