- TIUPUTU ; SLC/JER - Utilities for Filer/Router ;1/16/04
- ;;1.0;TEXT INTEGRATION UTILITIES;**3,100,120,113**;Jun 20, 1997
- LOOKUP ; Look-up code used by router/filer
- ; Required: TIUSSN, TIUADT
- N DA,DFN,TIU,TIUDAD,TIUDPRM,TIUEDIT,TIUEDT,TIULDT,TIUXCRP S TIUXCRP=1
- I $S('$D(TIUSSN):1,'$D(TIUADT):1,$G(TIUSSN)?4N:1,$G(TIUSSN)']"":1,1:0) S Y=-1 G LOOKUPX
- I TIUSSN?3N1P2N1P4N.E S TIUSSN=$TR(TIUSSN,"-/","")
- I TIUSSN["?" S Y=-1 G LOOKUPX
- S TIUEDT=$$IDATE^TIULC(TIUADT),TIULDT=$$FMADD^XLFDT(TIUEDT,1)
- I +TIUEDT'>0 S Y=-1 Q
- D MAIN^TIUMOVE(.TIU,.DFN,TIUSSN,TIUEDT,TIULDT,1,"LAST",0)
- I $S($D(TIU)'>9:1,+$G(DFN)'>0:1,1:0) S Y=-1 G LOOKUPX
- S TIUINST=+$$DIVISION^TIULC1(TIU("LOC"))
- I $P(+$G(TIU("EDT")),".")'=$P($$IDATE^TIULC(TIUADT),".") S Y=-1 G LOOKUPX
- I '+$G(TIU("LDT")),($G(TIUDICDT)]""),(+$$IDATE^TIULC(TIUDICDT)=-1) S Y=-1 Q
- D DOCPRM^TIULC1(RECORD("TYPE"),.TIUDPRM)
- S TIUTYP(1)=1_U_RECORD("TYPE")_U_$$PNAME^TIULC1(RECORD("TYPE"))
- S Y=$$GETRECNW^TIUEDI3(DFN,.TIU,TIUTYP(1),.TIUNEW,.TIUDPRM)
- I +Y'>0 G LOOKUPX
- S TIUEDIT=$$CANEDIT(+Y)
- ; If record has text and can be edited, then replace existing text
- I +TIUEDIT>0,$D(^TIU(8925,+Y,"TEXT")) D DELTEXT(+Y)
- I +TIUEDIT'>0 S TIUDAD=+Y,Y=$$MAKEADD
- I +Y'>0 G LOOKUPX
- K TIUHDR(.07)
- D STUFREC(Y,+$G(TIUDAD))
- I +$G(TIUDAD) D SENDADD^TIUALRT(+Y)
- LOOKUPX Q
- CANEDIT(DA) ; Check whether or not document is released
- Q $S(+$P($G(^TIU(8925,+DA,13)),U,4):0,+$P($G(^(13)),U,5)>0:0,+$G(^(15)):0,1:1)
- MAKEADD() ; Create an addendum record
- N DIE,DR,DA,DIC,X,Y,DLAYGO,TIUATYP,TIUFPRIV S TIUFPRIV=1
- S TIUATYP=+$$WHATITLE("ADDENDUM")
- S (DIC,DLAYGO)=8925,DIC(0)="L",X=""""_"`"_TIUATYP_""""
- D ^DIC
- S DA=+Y
- I +DA>0 S DIE=DIC,DR=".04////"_$$DOCCLASS^TIULC1(TIUATYP) D ^DIE
- Q +DA
- STUFREC(DA,PARENT) ; Stuff fixed field data
- N FDA,FDARR,IENS,FLAGS,TIUMSG,TIURDT
- S IENS=""""_DA_",""",FDARR="FDA(8925,"_IENS_")",FLAGS="K"
- I +$G(PARENT)'>0 D
- . S @FDARR@(.02)=$G(DFN),@FDARR@(.03)=$P($G(TIU("VISIT")),U)
- . S @FDARR@(.05)=3
- . S @FDARR@(.07)=$P(TIU("EDT"),U)
- . S @FDARR@(.08)=$P(TIU("LDT"),U),@FDARR@(1401)=TIU("AD#")
- . S @FDARR@(1402)=$P($G(TIU("TS")),U),@FDARR@(1201)=$$NOW^TIULC
- I +$G(PARENT)>0 D
- . S @FDARR@(.02)=+$P(^TIU(8925,+PARENT,0),U,2)
- . S @FDARR@(.03)=+$P(^TIU(8925,+PARENT,0),U,3),@FDARR@(.05)=3
- . S @FDARR@(.06)=PARENT,@FDARR@(.08)=$P(TIU("LDT"),U)
- . S @FDARR@(1401)=$P(^TIU(8925,+PARENT,14),U)
- . S @FDARR@(1402)=$P(^TIU(8925,+PARENT,14),U,2)
- . S @FDARR@(1201)=$$NOW^TIULC
- S @FDARR@(1205)=$P($G(TIU("LOC")),U)
- S @FDARR@(1212)=$P($G(TIU("INST")),U)
- I +$G(TIU("LDT")) S TIURDT=+$G(TIU("LDT"))
- I +$G(TIU("LDT"))'>0 D
- . S TIUDICDT=+$$IDATE^TIULC($G(TIUDICDT))
- . S TIURDT=$S(+$G(TIUDICDT)>0:+$G(TIUDICDT),1:+$$NOW^TIULC)
- . S TIU("LDT")=TIURDT_U_$$DATE^TIULS(TIURDT,"AMTH DD, CCYY@HR:MIN:SEC")
- . S @FDARR@(.12)=1
- S @FDARR@(1301)=TIURDT,@FDARR@(1303)="U"
- D FILE^DIE(FLAGS,"FDA","TIUMSG") ; File record
- Q
- DELTEXT(DA) ; Delete existing text in preparation for replacement
- N DIE,DR,X,Y
- S DIE=8925,DR="2///@" D ^DIE
- Q
- WHATYPE(X) ; Identify document type
- ; Receives: X=Document Definition Name
- ; Returns: Y=Document Definition IFN
- N DIC,Y,TIUFPRIV S TIUFPRIV=1
- S DIC=8925.1,DIC(0)="M"
- S DIC("S")="I +$O(^TIU(8925.1,+Y,""HEAD"",0))!+$O(^TIU(8925.1,+Y,""ITEM"",0))"
- D ^DIC K DIC("S")
- Q Y
- WHATYPE2(X) ; Identify document type
- ; Receives: X=Document Definition Name
- ; Returns: Y=Document Definition IFN
- N DIC,Y,TIUFPRIV S TIUFPRIV=1
- S DIC=8925.1,DIC(0)="M"
- S DIC("S")="I +$O(^TIU(8925.1,+Y,""HEAD"",0))!+$O(^TIU(8925.1,+Y,""ITEM"",0))"
- D ^DIC K DIC("S")
- Q Y
- WHATITLE(X) ; Identify document type
- ; Receives: X=Document Definition Name
- ; Returns: Y=Document Definition IFN
- N DIC,Y,TIUFPRIV S TIUFPRIV=1
- S DIC=8925.1,DIC(0)="M"
- S DIC("S")="I $P(^TIU(8925.1,+Y,0),U,4)=""DOC"""
- D ^DIC K DIC("S")
- Q Y
- FOLLOWUP(TIUDA) ; Post-filing code for Discharge Summaries
- N FDA,FDARR,IENS,FLAGS,TIUMSG,TIU
- S IENS=""""_TIUDA_",""",FDARR="FDA(8925,"_IENS_")",FLAGS="K"
- D GETTIU^TIULD(.TIU,TIUDA)
- I $L($G(TIU("EDT"))) S @FDARR@(.07)=$P($G(TIU("EDT")),U)
- S @FDARR@(1204)=$$WHOSIGNS^TIULC1(TIUDA)
- S @FDARR@(1208)=$$WHOCOSIG^TIULC1(TIUDA)
- D FILE^DIE(FLAGS,"FDA","TIUMSG")
- I +$P($G(^TIU(8925,+TIUDA,12)),U,4)'=+$P($G(^(12)),U,9) D
- . S @FDARR@(1506)=1 D FILE^DIE(FLAGS,"FDA","TIUMSG")
- D ENQ^TIUPXAP1 ; In-line call to get/file the visit
- D RELEASE^TIUT(TIUDA,1),UPDTIRT^TIUDIRT(.TIU,TIUDA)
- D AUDIT^TIUEDI1(TIUDA,0,$$CHKSUM^TIULC("^TIU(8925,"_+TIUDA_",""TEXT"")"))
- Q
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HTIUPUTU 4545 printed Feb 19, 2025@00:11:11 Page 2
- TIUPUTU ; SLC/JER - Utilities for Filer/Router ;1/16/04
- +1 ;;1.0;TEXT INTEGRATION UTILITIES;**3,100,120,113**;Jun 20, 1997
- LOOKUP ; Look-up code used by router/filer
- +1 ; Required: TIUSSN, TIUADT
- +2 NEW DA,DFN,TIU,TIUDAD,TIUDPRM,TIUEDIT,TIUEDT,TIULDT,TIUXCRP
- SET TIUXCRP=1
- +3 IF $SELECT('$DATA(TIUSSN):1,'$DATA(TIUADT):1,$GET(TIUSSN)?4N:1,$GET(TIUSSN)']"":1,1:0)
- SET Y=-1
- GOTO LOOKUPX
- +4 IF TIUSSN?3N1P2N1P4N.E
- SET TIUSSN=$TRANSLATE(TIUSSN,"-/","")
- +5 IF TIUSSN["?"
- SET Y=-1
- GOTO LOOKUPX
- +6 SET TIUEDT=$$IDATE^TIULC(TIUADT)
- SET TIULDT=$$FMADD^XLFDT(TIUEDT,1)
- +7 IF +TIUEDT'>0
- SET Y=-1
- QUIT
- +8 DO MAIN^TIUMOVE(.TIU,.DFN,TIUSSN,TIUEDT,TIULDT,1,"LAST",0)
- +9 IF $SELECT($DATA(TIU)'>9:1,+$GET(DFN)'>0:1,1:0)
- SET Y=-1
- GOTO LOOKUPX
- +10 SET TIUINST=+$$DIVISION^TIULC1(TIU("LOC"))
- +11 IF $PIECE(+$GET(TIU("EDT")),".")'=$PIECE($$IDATE^TIULC(TIUADT),".")
- SET Y=-1
- GOTO LOOKUPX
- +12 IF '+$GET(TIU("LDT"))
- IF ($GET(TIUDICDT)]"")
- IF (+$$IDATE^TIULC(TIUDICDT)=-1)
- SET Y=-1
- QUIT
- +13 DO DOCPRM^TIULC1(RECORD("TYPE"),.TIUDPRM)
- +14 SET TIUTYP(1)=1_U_RECORD("TYPE")_U_$$PNAME^TIULC1(RECORD("TYPE"))
- +15 SET Y=$$GETRECNW^TIUEDI3(DFN,.TIU,TIUTYP(1),.TIUNEW,.TIUDPRM)
- +16 IF +Y'>0
- GOTO LOOKUPX
- +17 SET TIUEDIT=$$CANEDIT(+Y)
- +18 ; If record has text and can be edited, then replace existing text
- +19 IF +TIUEDIT>0
- IF $DATA(^TIU(8925,+Y,"TEXT"))
- DO DELTEXT(+Y)
- +20 IF +TIUEDIT'>0
- SET TIUDAD=+Y
- SET Y=$$MAKEADD
- +21 IF +Y'>0
- GOTO LOOKUPX
- +22 KILL TIUHDR(.07)
- +23 DO STUFREC(Y,+$GET(TIUDAD))
- +24 IF +$GET(TIUDAD)
- DO SENDADD^TIUALRT(+Y)
- LOOKUPX QUIT
- CANEDIT(DA) ; Check whether or not document is released
- +1 QUIT $SELECT(+$PIECE($GET(^TIU(8925,+DA,13)),U,4):0,+$PIECE($GET(^(13)),U,5)>0:0,+$GET(^(15)):0,1:1)
- MAKEADD() ; Create an addendum record
- +1 NEW DIE,DR,DA,DIC,X,Y,DLAYGO,TIUATYP,TIUFPRIV
- SET TIUFPRIV=1
- +2 SET TIUATYP=+$$WHATITLE("ADDENDUM")
- +3 SET (DIC,DLAYGO)=8925
- SET DIC(0)="L"
- SET X=""""_"`"_TIUATYP_""""
- +4 DO ^DIC
- +5 SET DA=+Y
- +6 IF +DA>0
- SET DIE=DIC
- SET DR=".04////"_$$DOCCLASS^TIULC1(TIUATYP)
- DO ^DIE
- +7 QUIT +DA
- STUFREC(DA,PARENT) ; Stuff fixed field data
- +1 NEW FDA,FDARR,IENS,FLAGS,TIUMSG,TIURDT
- +2 SET IENS=""""_DA_","""
- SET FDARR="FDA(8925,"_IENS_")"
- SET FLAGS="K"
- +3 IF +$GET(PARENT)'>0
- Begin DoDot:1
- +4 SET @FDARR@(.02)=$GET(DFN)
- SET @FDARR@(.03)=$PIECE($GET(TIU("VISIT")),U)
- +5 SET @FDARR@(.05)=3
- +6 SET @FDARR@(.07)=$PIECE(TIU("EDT"),U)
- +7 SET @FDARR@(.08)=$PIECE(TIU("LDT"),U)
- SET @FDARR@(1401)=TIU("AD#")
- +8 SET @FDARR@(1402)=$PIECE($GET(TIU("TS")),U)
- SET @FDARR@(1201)=$$NOW^TIULC
- End DoDot:1
- +9 IF +$GET(PARENT)>0
- Begin DoDot:1
- +10 SET @FDARR@(.02)=+$PIECE(^TIU(8925,+PARENT,0),U,2)
- +11 SET @FDARR@(.03)=+$PIECE(^TIU(8925,+PARENT,0),U,3)
- SET @FDARR@(.05)=3
- +12 SET @FDARR@(.06)=PARENT
- SET @FDARR@(.08)=$PIECE(TIU("LDT"),U)
- +13 SET @FDARR@(1401)=$PIECE(^TIU(8925,+PARENT,14),U)
- +14 SET @FDARR@(1402)=$PIECE(^TIU(8925,+PARENT,14),U,2)
- +15 SET @FDARR@(1201)=$$NOW^TIULC
- End DoDot:1
- +16 SET @FDARR@(1205)=$PIECE($GET(TIU("LOC")),U)
- +17 SET @FDARR@(1212)=$PIECE($GET(TIU("INST")),U)
- +18 IF +$GET(TIU("LDT"))
- SET TIURDT=+$GET(TIU("LDT"))
- +19 IF +$GET(TIU("LDT"))'>0
- Begin DoDot:1
- +20 SET TIUDICDT=+$$IDATE^TIULC($GET(TIUDICDT))
- +21 SET TIURDT=$SELECT(+$GET(TIUDICDT)>0:+$GET(TIUDICDT),1:+$$NOW^TIULC)
- +22 SET TIU("LDT")=TIURDT_U_$$DATE^TIULS(TIURDT,"AMTH DD, CCYY@HR:MIN:SEC")
- +23 SET @FDARR@(.12)=1
- End DoDot:1
- +24 SET @FDARR@(1301)=TIURDT
- SET @FDARR@(1303)="U"
- +25 ; File record
- DO FILE^DIE(FLAGS,"FDA","TIUMSG")
- +26 QUIT
- DELTEXT(DA) ; Delete existing text in preparation for replacement
- +1 NEW DIE,DR,X,Y
- +2 SET DIE=8925
- SET DR="2///@"
- DO ^DIE
- +3 QUIT
- WHATYPE(X) ; Identify document type
- +1 ; Receives: X=Document Definition Name
- +2 ; Returns: Y=Document Definition IFN
- +3 NEW DIC,Y,TIUFPRIV
- SET TIUFPRIV=1
- +4 SET DIC=8925.1
- SET DIC(0)="M"
- +5 SET DIC("S")="I +$O(^TIU(8925.1,+Y,""HEAD"",0))!+$O(^TIU(8925.1,+Y,""ITEM"",0))"
- +6 DO ^DIC
- KILL DIC("S")
- +7 QUIT Y
- WHATYPE2(X) ; Identify document type
- +1 ; Receives: X=Document Definition Name
- +2 ; Returns: Y=Document Definition IFN
- +3 NEW DIC,Y,TIUFPRIV
- SET TIUFPRIV=1
- +4 SET DIC=8925.1
- SET DIC(0)="M"
- +5 SET DIC("S")="I +$O(^TIU(8925.1,+Y,""HEAD"",0))!+$O(^TIU(8925.1,+Y,""ITEM"",0))"
- +6 DO ^DIC
- KILL DIC("S")
- +7 QUIT Y
- WHATITLE(X) ; Identify document type
- +1 ; Receives: X=Document Definition Name
- +2 ; Returns: Y=Document Definition IFN
- +3 NEW DIC,Y,TIUFPRIV
- SET TIUFPRIV=1
- +4 SET DIC=8925.1
- SET DIC(0)="M"
- +5 SET DIC("S")="I $P(^TIU(8925.1,+Y,0),U,4)=""DOC"""
- +6 DO ^DIC
- KILL DIC("S")
- +7 QUIT Y
- FOLLOWUP(TIUDA) ; Post-filing code for Discharge Summaries
- +1 NEW FDA,FDARR,IENS,FLAGS,TIUMSG,TIU
- +2 SET IENS=""""_TIUDA_","""
- SET FDARR="FDA(8925,"_IENS_")"
- SET FLAGS="K"
- +3 DO GETTIU^TIULD(.TIU,TIUDA)
- +4 IF $LENGTH($GET(TIU("EDT")))
- SET @FDARR@(.07)=$PIECE($GET(TIU("EDT")),U)
- +5 SET @FDARR@(1204)=$$WHOSIGNS^TIULC1(TIUDA)
- +6 SET @FDARR@(1208)=$$WHOCOSIG^TIULC1(TIUDA)
- +7 DO FILE^DIE(FLAGS,"FDA","TIUMSG")
- +8 IF +$PIECE($GET(^TIU(8925,+TIUDA,12)),U,4)'=+$PIECE($GET(^(12)),U,9)
- Begin DoDot:1
- +9 SET @FDARR@(1506)=1
- DO FILE^DIE(FLAGS,"FDA","TIUMSG")
- End DoDot:1
- +10 ; In-line call to get/file the visit
- DO ENQ^TIUPXAP1
- +11 DO RELEASE^TIUT(TIUDA,1)
- DO UPDTIRT^TIUDIRT(.TIU,TIUDA)
- +12 DO AUDIT^TIUEDI1(TIUDA,0,$$CHKSUM^TIULC("^TIU(8925,"_+TIUDA_",""TEXT"")"))
- +13 QUIT