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

BTIUPRT1.m

Go to the documentation of this file.
BTIUPRT1 ;IHS/MSC/MGH - Print special header and foot notes;18-Mar-2015 12:30;MGH
 ;;1.0;TEXT INTEGRATION UTILITIES;**1008,1013**;Jun 20, 1997;Build 33
 ;Copy of TIUPRPN1 Print SF 509-Progress Notes ;26-Feb-2010 11:59;MGH
 ;IHS/ITSC/LJF 02/26/2003 added code to check for clinc not defined for visit
PRINT(TIUTYPE,TIUFLAG,TIUSPG) ; Print Document
 ; ^TMP("TIUPR",$J) is array of records to be printed
 ; TIUFLAG=1 --> Chart Copy     TIUSPG=1 --> Contiguous
 ; TIUFLAG=0 --> Work Copy      TIUSPG=0 --> Fresh Page- each note
 ; TIUCONT=1 --> Continue printing
 ; TIUCONT1=1 --> Write "Continue to next/from previous-page" msgs
 ; TIUPFNBR ---> Print Form # like vice 509
 ; TIUMISC=TIUFLAG_U_TIUPFNBR_U_TIUDA
 N TIUI,TIUJ,TIUPAGE,TIUFOOT,TIUK,TIUDA,TIUCONT,TIUPGRP,TIUTYP
 N TIUPFHDR,TIUPFNBR,TIUMISC,TIUCONT1,TIUIDONE,TMP,HEADER,FOOTER
 S TIUFLAG=+$G(TIUFLAG),TIUSPG=+$G(TIUSPG)
 S TIUCONT=1,TIUCONT1=0
 S TIUI=0 F  S TIUI=$O(^TMP("TIUPR",$J,TIUI)) Q:TIUI=""  D  Q:'TIUCONT
 . N DFN,TIU
 . I TIUI["$" S TIUPGRP=$P(TIUI,"$"),TIUPFHDR=$P($P(TIUI,";"),"$",2)
 . E  S TIUPFHDR="Progress Notes"
 . I $G(TIUPGRP)>2 S TIUSPG=0
 . S DFN=$P(TIUI,";",2)
 . D PATPN^TIULV(.TIUFOOT,DFN)
 . ;IHS/MSC/MGH check for header
 .S HEADER=$$CHECK(TIUTYPE,2)
 .I +HEADER D
 ..I $G(TIUSPG) D HEADER^BTIUPRT2(TIUFLAG,TIUCONT1,HEADER,TIUK,DFN)
 .E  D
 ..I +$G(TIUSPG) D HEADER^TIUPRPN2(.TIUFOOT,TIUFLAG,.TIUPFHDR,TIUCONT1)
 . ; Use TIUJ="" (not TIUJ=0), to print "complete" notes w/o sigdt:
 . S TIUJ="" F  S TIUJ=$O(^TMP("TIUPR",$J,TIUI,TIUJ)) Q:TIUJ=""  D  Q:'TIUCONT
 . . S TIUK=0 F  S TIUK=$O(^TMP("TIUPR",$J,TIUI,TIUJ,TIUK)) Q:'TIUK  D  Q:'TIUCONT
 . . . S TIUCONT1=0 S TIUPFNBR=^TMP("TIUPR",$J,TIUI,TIUJ,TIUK)
 . . . ; If the document has been deleted, QUIT
 . . . I '$D(^TIU(8925,+TIUK,0)) S TIUCONT=1 Q
 . . . N TIUROOT
 . . . S HEADER=$$CHECK(TIUTYPE,2)
 . . . I +HEADER D
 . . . . I '+$G(TIUSPG) D HEADER^BTIUPRT2(TIUFLAG,TIUCONT1,HEADER,TIUK,DFN)
 . . . E  D
 . . . . I '+$G(TIUSPG) D HEADER^TIUPRPN2(.TIUFOOT,TIUFLAG,.TIUPFHDR,TIUCONT1)
 . . . S TIUDA=TIUK
 . . . S TIUMISC=TIUFLAG_U_TIUPFNBR_U_TIUDA
 . . . K ^TMP("TIULQ",$J)
 . . . D EXTRACT^TIULQ(+TIUDA,"^TMP(""TIULQ"",$J)",.TIUERR,"","",1)
 . . . I +$G(TIUERR) W !,$P(TIUERR,U,2) Q
 . . . Q:'$D(^TMP("TIULQ",$J))
 . . . S TIUROOT="^TMP(""TIULQ"",$J,"_TIUDA_")"
 . . . D REPORT(TIUROOT,.TIUFOOT,TIUMISC,.TIUCONT) Q:'TIUCONT
 . . . D IDKIDS(TIUROOT,.TIUFOOT,TIUMISC,TIUCONT1,.TIUCONT) Q:'TIUCONT
 . . . I '+$G(TIUSPG) S TIUCONT1=0 S TIUCONT=$$SETCONT(.TIUFOOT,TIUMISC,TIUCONT1,1,$G(TIUROOT),TIUTYPE)
 . Q:'TIUCONT
 . I $E(IOST)="C" S TIUCONT=$$STOP^TIUPRPN2() Q:'TIUCONT
 . I +$G(TIUSPG),$E(IOST)'="C" S TIUCONT1=0 S TIUCONT=$$SETCONT(.TIUFOOT,TIUMISC,TIUCONT1,1,$G(TIUROOT),TIUTYPE)
 Q
 ;
REPORT(TIUROOT,TIUFOOT,TIUMISC,TIUCONT,TIUIDEND) ; Report Text
 ; Requires array TIUFOOT, vars TIUMISC, TIUCONT
 ; Requires TIUROOT =
 ; ^TMP("TIULQ",$J,NOTEIFN) for parent/stand-alone note, or
 ; ^TMP("TIULQ",$J,NOTEIFN,"ZADD",ADDMIFN) for addendum, or
 ; ^TMP("TIULQ",$J,NOTEIFN,"ZZID",KIDSEQ#,IDKIDIFN) for ID kid, or
 ; ^TMP("TIULQ",$J,NOTEIFN,"ZZID",KIDSEQ#,IDKIDIFN,"ZADD",KIDADDMIFN)
 ;       for ID kid addm.
 N DIW,DIWF,DIWL,DIWR,DIWT,TIUERR,TIU,TIUI,X,Z,LOC
 N REFDT,TITLE,ADT,HLOC,SUBJ
 N TIUDA,TIUCONT1,HASIDKID,HASIDDAD
 S TIUDA=$P(TIUMISC,U,3),TIUCONT1=0
 S TIUCONT=$$SETCONT(.TIUFOOT,TIUMISC,TIUCONT1,0,$G(TIUROOT),TIUTYPE) Q:'TIUCONT
 S HASIDKID=$G(^TMP("TIULQ",$J,TIUDA,"ZZID",0)) ;how many ID kids
 S HASIDDAD=$S(TIUROOT["ZZID":1,1:0)
 I HASIDKID W "<< Interdisciplinary Note - Begin >>",!
 I HASIDDAD W "<< Interdisciplinary Note - Cont. >>",!
 W $S('HASIDKID&'HASIDDAD:"NOTE DATED: ",1:"ENTRY DATED: ")
 S REFDT=@TIUROOT@(1301,"I")
 W $$DATE^TIULS(REFDT,"MM/DD/CCYY HR:MIN")
 S TITLE=@TIUROOT@(.01,"E")
 W ?30,$$UP^XLFSTR(TITLE),!
 S LOC=$G(@TIUROOT@(1205,"I"))
 I +LOC D
 . ;W $S($P(^SC(LOC,0),U,3)="W":"ADMITTED: ",1:"VISIT: ")     ;IHS/ITSC/LJF 02/26/2003
 . W $S($P($G(^SC(LOC,0)),U,3)="W":"ADMITTED: ",1:"VISIT: ")  ;IHS/ITSC/LJF 02/26/2003 check for null clinic
 . S ADT=$G(@TIUROOT@(.07,"I"))
 . W $$DATE^TIULS(ADT,"MM/DD/CCYY HR:MIN")
 . S HLOC=$G(@TIUROOT@(1205,"E"))
 . W " ",HLOC
 S SUBJ=$G(@TIUROOT@(1701,"E"))
 I SUBJ]"" W !,"SUBJECT: ",^("E"),!
 S TIUCONT1=1
 I $D(@TIUROOT@("PROBLEM")) D  Q:'TIUCONT
 . S TIUCONT=$$SETCONT(.TIUFOOT,TIUMISC,TIUCONT1,0,$G(TIUROOT),TIUTYPE) Q:'TIUCONT
 . W !,"ASSOCIATED PROBLEMS:"
 . N TIUI S TIUI=0
 . F  S TIUI=$O(@TIUROOT@("PROBLEM",TIUI)) Q:'TIUI  D  Q:'TIUCONT
 ..W !,^(TIUI,0)
 ..S TIUCONT=$$SETCONT(.TIUFOOT,TIUMISC,TIUCONT1,0,$G(TIUROOT),TIUTYPE) Q:'TIUCONT
 W !
 S TIUI=0,DIWF="WN",DIWL=1,DIWR=79 K ^UTILITY($J,"W")
 F  S TIUI=$O(@TIUROOT@("TEXT",TIUI)) Q:TIUI'>0  D  Q:'TIUCONT  ; D ^DIWW
 . S TIUCONT=$$SETCONT(.TIUFOOT,TIUMISC,TIUCONT1,0,$G(TIUROOT),TIUTYPE) Q:'TIUCONT
 . S X=@TIUROOT@("TEXT",TIUI,0) S:X="" X=" " D ^DIWP
 D ^DIWW K ^UTILITY($J,"W")
 Q:'TIUCONT
 D GETSIG(TIUROOT,.TIUSIG)
 S TIUCONT=$$SETCONT(.TIUFOOT,TIUMISC,TIUCONT1,0,$G(TIUROOT),TIUTYPE) Q:'TIUCONT
 W !
 D SIGBLK^TIUPRPN8(.TIUFOOT,TIUMISC,TIUCONT1,.TIUCONT,.TIUSIG,TIUROOT)
 Q:'TIUCONT
ADDENDA ; Fall through and do Addenda of docmt TIUDA
 N DIW,DIWF,DIWL,DIWR,DIWT,X,Z,TIUI,TIUADD,ADDMRDT
 S TIUADD=0,DIWF="WN",DIWL=1,DIWR=79 K ^UTILITY($J,"W")
 F  S TIUADD=$O(@TIUROOT@("ZADD",TIUADD)) Q:TIUADD'>0  D  Q:'TIUCONT
 . S TIUCONT=$$SETCONT(.TIUFOOT,TIUMISC,TIUCONT1,0,$G(TIUROOT),TIUTYPE) Q:'TIUCONT
 . S ADDMRDT=@TIUROOT@("ZADD",TIUADD,1301,"I")
 . W !!,$$DATE^TIULS(ADDMRDT,"MM/DD/CCYY HR:MIN"),?21,"ADDENDUM"
 . W ?39,"STATUS: ",@TIUROOT@("ZADD",TIUADD,.05,"E") ;P162
 . S TIUI=0
 . F  S TIUI=$O(@TIUROOT@("ZADD",TIUADD,"TEXT",TIUI)) Q:TIUI'>0  D  Q:'TIUCONT
 . . S TIUCONT=$$SETCONT(.TIUFOOT,TIUMISC,TIUCONT1,0,$G(TIUROOT),TIUTYPE) Q:'TIUCONT
 . . S X=@TIUROOT@("ZADD",TIUADD,"TEXT",TIUI,0) S:X="" X=" " D ^DIWP
 . D ^DIWW
 . Q:'TIUCONT
 . N TIUADRT
 . S TIUADRT=$P(TIUROOT,")")_",""ZADD"","_TIUADD_")"
 . D GETSIG(TIUADRT,.TIUSIG)
 . D SIGBLK^TIUPRPN8(.TIUFOOT,TIUMISC,TIUCONT1,.TIUCONT,.TIUSIG,TIUADRT)
 ; Need ! in front for amended notes:
 I $G(TIUIDEND) W !,"<< Interdisciplinary Note - End >>",!
 K ^UTILITY($J,"W")
 ; Write 2 linefeeds between records
 W:TIUCONT !!
 Q
 ;
IDKIDS(TIUROOT,TIUFOOT,TIUMISC,TIUCONT1,TIUCONT) ; Print ID kids
 ;of docmt TIUDA (each kid does its own addenda)
 N TIUL,KIDDA,TIUDA,TIUSORT,TIUIDRT,TIUIDEND
 S TIUDA=$P(TIUMISC,U,3),TIUIDEND=0
 S TIUL=0
 F  S TIUL=$O(^TMP("TIULQ",$J,TIUDA,"ZZID",TIUL)) Q:'TIUL  D  Q:'TIUCONT
 . S KIDDA=$O(^TMP("TIULQ",$J,TIUDA,"ZZID",TIUL,0))
 . S TIUMISC=TIUFLAG_U_TIUPFNBR_U_KIDDA
 . S TIUIDRT="^TMP(""TIULQ"",$J,"_TIUDA_",""ZZID"","_TIUL_","_KIDDA_")"
 . I '$O(^TMP("TIULQ",$J,TIUDA,"ZZID",TIUL)) S TIUIDEND=1
 . D REPORT(TIUIDRT,.TIUFOOT,TIUMISC,.TIUCONT,TIUIDEND)
 Q
 ;
GETSIG(TIUROOT,TIUSIG) ; Get signature info from TIULQ global;
 ; Set info into TIUSIG array **100**
 ; Requires array name TIUROOT; passes back array TIUSIG
 ; TIUROOT = ^TMP("TIULQ",$J,NOTEIFN) for parent note, or
 ;           ^TMP("TIULQ",$J,NOTEIFN,"ZADD",ADDMIFN) for addendum, or
 ;           ^TMP("TIULQ",$J,NOTEIFN,"ZZID",IDKIDIFN) for ID kid.
 ; Signature should be on bottom of form, Addenda on Subsequent pages
 N TIULINE S $P(TIULINE,"-",81)=""
 S TIUSIG("AUTHOR")=$G(@TIUROOT@(1202,"I"))_";"_$G(^("E"))
 S TIUSIG("EXPSIGNR")=$G(@TIUROOT@(1204,"I"))_";"_$G(^("E"))
 S TIUSIG("EXPCOSNR")=$G(@TIUROOT@(1208,"I"))_";"_$G(^("E"))
 S TIUSIG("SIGNDATE")=$G(@TIUROOT@(1501,"I"))
 S TIUSIG("SIGNEDBY")=$G(@TIUROOT@(1502,"I"))_";"_$G(^("E"))
 S TIUSIG("SIGNNAME")=$G(@TIUROOT@(1503,"E"))
 S TIUSIG("SIGTITL")=$G(@TIUROOT@(1504,"E"))
 S TIUSIG("SIGNMODE")=$G(@TIUROOT@(1505,"I"))_";"_$G(^("E"))
 S TIUSIG("COSGDATE")=$G(@TIUROOT@(1507,"I"))
 S TIUSIG("COSGEDBY")=$G(@TIUROOT@(1508,"I"))_";"_$G(^("E"))
 S TIUSIG("COSGNAME")=$G(@TIUROOT@(1509,"E"))
 S TIUSIG("COSGTITL")=$G(@TIUROOT@(1510,"E"))
 S TIUSIG("COSGMODE")=$G(@TIUROOT@(1511,"I"))_";"_$G(^("E"))
 S TIUSIG("SIGCHRT")=$G(@TIUROOT@(1512,"I"))_";"_$G(^("E"))
 S TIUSIG("COSCHRT")=$G(@TIUROOT@(1513,"I"))_";"_$G(^("E"))
 ; -- P182 Set Admin Clos Date:
 ;IHS/MSC/MGH added in 1013
 S TIUSIG("ADMINCDT")=$G(@TIUROOT@(1606,"I"))_";"_$G(^("E"))
 Q
CHECK(TIUTITLE,TEMPLATE) ;See if there is a header for this note title
 N IEN,TIEN,DIV,TITLE
 S TIEN=""
 S DIV="" S DIV=$O(^DG(40.8,"AD",DUZ(2),DIV)) Q:DIV=""  D
 .S TITLE=TIUTITLE,IEN=""
 .S IEN=$O(^TIU(8925.94,DIV,9999999.11,"B",TITLE,IEN)) Q:IEN=""  D
 ..S TIEN=$P($G(^TIU(8925.94,DIV,9999999.11,IEN,0)),U,TEMPLATE)
 Q TIEN
 ;
SETCONT(TIUFOOT,TIUMISC,TIUCONT1,TIUHEAD,TIUROOT,TIUTYPE) ;Does footer
 ;and returns TIUCONT
 ; Requires array TIUFOOT, vars TIUMISC,TIUCONT1; optional TIUHEAD
 ; Optional TIUROOT
 ;Check for special footer
 N X
 S FOOTER=$$CHECK(TIUTYPE,3)
 I +FOOTER S X=$$FOOTER^BTIUPRT2(TIUMISC,TIUCONT1,TIUHEAD,$G(TIUROOT),FOOTER,TIUK,DFN)
 E  S X=$$FOOTER^TIUPRPN2(.TIUFOOT,TIUMISC,TIUCONT1,TIUHEAD,$G(TIUROOT))
 Q X