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

TIUPUTC1.m

Go to the documentation of this file.
  1. TIUPUTC1 ; SLC/JER,AJB - Document filer Cont'd - captioned header ;Jul 09, 2020@12:06:28
  1. ;;1.0;TEXT INTEGRATION UTILITIES;**81,290,335**;Jun 20, 1997;Build 3
  1. ;
  1. GETREC(HEADER,RECORD,TIUHDR) ; ---- Look-up/create record (if LAYGO allowed)
  1. N DIC,DLAYGO,TIUD1,TIUD4,TIUKEY,X,Y,TIUDSFTR
  1. I '$D(ZTQUEUED) W !!,">>> HEADER IDENTIFIED:",!,HEADER
  1. S X=$$STRIP^TIULS($P(HEADER,":",2)),Y=$$WHATYPE^TIUPUTU(X)
  1. I +Y'>0 D MAIN^TIUPEVNT(DA,1,3,X) D Q
  1. . W:'$D(ZTQUEUED) !!,"INVALID DOCUMENT TYPE ",X,".",!
  1. . S ^TMP("TIUPUTC",$J,"FAIL")=+$G(^TMP("TIUPUTC",$J,"FAIL"))+1
  1. S TIUD1=$G(^TIU(8925.1,+Y,1)),TIUD4=$G(^TIU(8925.1,+Y,4))
  1. S RECORD("TYPE")=+Y,RECORD("FILE")=$P(TIUD1,U)
  1. S RECORD("BOILON")=$P(TIUD1,U,4)
  1. I RECORD("FILE")']"" D MAIN^TIUPEVNT(DA,1,4,X) D Q
  1. . W:'$D(ZTQUEUED) !!,"TARGET FILE NOT DEFINED FOR ",X,".",!
  1. . S ^TMP("TIUPUTC",$J,"FAIL")=+$G(^TMP("TIUPUTC",$J,"FAIL"))+1
  1. S RECORD("ROOT")=$G(^DIC(+RECORD("FILE"),0,"GL"))
  1. I $P(TIUD1,U,3)']"" D MAIN^TIUPEVNT(DA,1,5,X) D Q
  1. . W:'$D(ZTQUEUED) !!,"TEXT FIELD NOT DEFINED FOR ",X,".",!
  1. . S ^TMP("TIUPUTC",$J,"FAIL")=+$G(^TMP("TIUPUTC",$J,"FAIL"))+1
  1. I $P(TIUD1,U,3)]"" D
  1. . ; ---- Get subscript of target file TEXT field
  1. . S RECORD("TEXT")=$P($P(TIUD1,U,3),";",2)
  1. . I RECORD("TEXT")]"",'+RECORD("TEXT") S RECORD("TEXT")=""""_RECORD("TEXT")_""""
  1. F D Q:TIULINE[TIUBGN!(+TIUI'>0)
  1. . N TIUNOD,TIUCAP,TIUVAR,TIUFIELD,TIUREQ S TIUREQ=0
  1. . ; ---- Reset TIUI and Write out transferred header info:
  1. . S TIUI=$O(^TIU(8925.2,+DA,"TEXT",TIUI)) Q:+TIUI'>0
  1. . S TIULINE=$G(^TIU(8925.2,+DA,"TEXT",TIUI,0)) Q:TIULINE[TIUBGN
  1. . I '$D(ZTQUEUED) W !,TIULINE
  1. . ; ---- Check for field number, required missing fields:
  1. . S TIUCAP=$P(TIULINE,":") Q:TIUCAP']""
  1. . S TIUNOD=$O(^TIU(8925.1,+RECORD("TYPE"),"HEAD","B",TIUCAP,0)) Q:+TIUNOD'>0
  1. . S TIUFIELD=$P(^TIU(8925.1,+RECORD("TYPE"),"HEAD",+TIUNOD,0),U,3)
  1. . I TIUFIELD']"" W:'$D(ZTQUEUED) !,"Field Number NOT SPECIFIED for ",TIUCAP Q
  1. . S TIUREQ=$P(^TIU(8925.1,+RECORD("TYPE"),"HEAD",+TIUNOD,0),U,7)
  1. . S TIUHDR(TIUFIELD)=$$STRIP^TIULS($P(TIULINE,":",2,99))
  1. . ;**TEST** - No future dictation dates for discharge summaries
  1. . I TIUFIELD=1307,$$ISA^TIULX($G(TIUREC("TYPE")),$$CHKFILE^TIUADCL(8925.1,"DISCHARGE SUMMARY","I $P(^(0),U,4)=""CL""")),$G(TIUHDR("1307"))]"" S TIUDSFTR=$$DICTDT(TIUHDR("1307")) I TIUDSFTR D Q
  1. . . S TIUHDR(TIUFIELD)="" I '$D(ZTQUEUED) W !,"**Future dictation dates are not allowed for this type of document**" S TIUFDT=1,^TMP("TIUPUTC",$J,"FAIL")=+$G(^TMP("TIUPUTC",$J,"FAIL"))+1 Q
  1. . I +TIUREQ,TIUHDR(TIUFIELD)="" S TIUHDR(TIUFIELD)="** REQUIRED FIELD MISSING FROM UPLOAD **"
  1. . ; ---- Get local lookup variables for document type:
  1. . S TIUVAR=$P(^TIU(8925.1,+RECORD("TYPE"),"HEAD",+TIUNOD,0),U,4) Q:TIUVAR']""
  1. . S TIUHDR(TIUVAR)=$$STRIP^TIULS($P(TIULINE,":",2,99))
  1. Q:TIUFDT=1 I '$D(ZTQUEUED) W !,TIUBGN,!
  1. S:+$P(TIUD1,U,2) DLAYGO=RECORD("FILE")
  1. ; Can't check if author Requires EC w/o Dict dt & AUTHOR so if not valid set FILING ERROR:
  1. N TIUVALID S TIUVALID="YES"
  1. I RECORD("TYPE")=3 D S TIUVALID=$S(TIUVALID["^":"NO",1:"YES") I TIUVALID="NO" D FAIL Q
  1. . ; added $G to CHK below ; *335 ajb
  1. . D CHK^DIE(8925,1307,,$G(TIUHDR("TIUDDT")),.TIUVALID) I TIUVALID["^" Q
  1. . D CHK^DIE(8925,1202,,$G(TIUHDR(1202)),.TIUVALID)
  1. ; ---- If a LOOKUP METHOD is defined for a given document type,
  1. ; then set lookup variables and call it:
  1. I $G(TIUD4)]"",TIUVALID="YES" D Q
  1. . N TIUJ,TIUVAR,TIUNOD S TIUVAR="A"
  1. . F S TIUVAR=$O(TIUHDR(TIUVAR)) Q:TIUVAR="" D
  1. . . S TIUJ=+$G(TIUJ)+1,TIUVAR(TIUJ)=TIUVAR
  1. . . S @TIUVAR=TIUHDR(TIUVAR)
  1. . X TIUD4 S RECORD("#")=+Y
  1. . I +Y'>0 D FAIL
  1. . ; ---- Kill local lookup variables:
  1. . S TIUJ=0 F S TIUJ=$O(TIUVAR(TIUJ)) Q:+TIUJ'>0 K @TIUVAR(TIUJ)
  1. ; Otherwise set-up for ^DIC call
  1. S DIC=RECORD("FILE"),DIC(0)="MX"
  1. S:+$P(TIUD1,U,2) DIC(0)=DIC(0)_"L"
  1. S:+$G(TIUHDR(.001)) DIC(0)=DIC(0)_"N"
  1. S TIUKEY=$S(+$G(TIUHDR(.001)):+$G(TIUHDR(.001)),1:$G(TIUHDR(.01)))
  1. S X=$S(DIC(0)["N":"`",1:"")_TIUKEY D ^DIC
  1. S RECORD("#")=+Y
  1. I +Y'>0 D
  1. . D MAIN^TIUPEVNT(DA,1,6,$P($G(^TIU(8925.1,+RECORD("TYPE"),0)),U))
  1. . ;W:'$D(ZTQUEUED) !!,"LOOK-UP FAILED FOR ",X,".",!
  1. . S ^TMP("TIUPUTC",$J,"FAIL")=+$G(^TMP("TIUPUTC",$J,"FAIL"))+1
  1. Q
  1. ;
  1. FAIL ; Log Filing Error
  1. ; ---- If lookup fails, log 8925.4 error w/ hdr info. Create new
  1. ; 8925.2 buffer entry with hdr, text, & 8925.4 log #.
  1. ; Kill most of old buffer. Send file error alerts:
  1. D MAIN^TIUPEVNT(DA,1,6,$P($G(^TIU(8925.1,+RECORD("TYPE"),0)),U))
  1. ;W:'$D(ZTQUEUED) !!,"LOOK-UP FAILED FOR ",X,".",!
  1. S ^TMP("TIUPUTC",$J,"FAIL")=+$G(^TMP("TIUPUTC",$J,"FAIL"))+1
  1. Q
  1. ;
  1. DICTDT(DATE) ;TEST** -- Returns 1 if Discharge Summary's Dictation Date is in the future, 0 otherwise
  1. N %,X,Y,%DT
  1. S X=DATE,%DT="T" D ^%DT Q:Y=-1 0 D NOW^%DTC Q Y>%
  1. ;