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

TIUASRPT.m

Go to the documentation of this file.
TIUASRPT ; SLC/JMH - Review unsigned additional signer Documents by DIVISION ;27-Mar-2013 08:22;DU
 ;;1.0;TEXT INTEGRATION UTILITIES;**157,1011**;Jun 20, 1997;Build 13
BEGIN ; Select Division(s), Entry Date Range, Service, Type of Report
 ; IHS/MSC/MGH Changed SSN to HRCN Patch 1011
 N TIUI,TIUSTDT,TIUENDT,TIUSVCS
 D SELDIV^TIULA Q:SELDIV'>0
 I $D(TIUDI) D
 . S TIUI=0 F  S TIUI=$O(TIUDI(TIUI)) Q:'TIUI  D
 . . S TIUDI("ENTRIES")=$G(TIUDI("ENTRIES"))_TIUI_";"
 E  D
 . S TIUDI("ENTRIES")="ALL DIVISIONS"
 ;
 ;Ask Date Range, exit if timeout, '^' or no selection
 Q:'$$ASKRNG(.TIUSTDT,.TIUENDT)
 ;
 ;Select Service, exit if timeout, '^' or no selection
 Q:'$$SELSVC^TIULA(.TIUSVCS)
 ;
 N DIR,DIRUT,DTOUT,DUOUT,TIURPT
 S DIR(0)="S^F:FULL;S:SUMMARY",DIR("A")="Type of Report"
 S DIR("?",1)="Summary lists the number of documents by author's"
 S DIR("?",2)="service/section. Full lists detailed document"
 S DIR("?",3)="information by author's service/section."
 S DIR("?")="Enter ""^"", or a RETURN to quit."
 D ^DIR Q:$D(DIRUT)  S TIURPT=Y
 ;
DEV ; Device selection
 I TIURPT="F" D
 . W !!,"This report should be sent to a 132 Column Device"
 S %ZIS="Q" W ! D ^%ZIS I POP K POP G EXIT
 I $D(IO("Q")) D  G EXIT
 . S ZTRTN="BUILD^TIUASRPT"
 . S ZTSAVE("TIUDI(")="",ZTSAVE("TIURPT")=""
 . S ZTSAVE("TIUSTDT")="",ZTSAVE("TIUENDT")=""
 . S ZTSAVE("TIUSVCS")="",ZTSAVE("TIUSVCS(")=""
 . S ZTDESC="TIU PENDING ADD. SIGNATURES BY DIV"
 . D ^%ZTLOAD W !,$S($D(ZTSK):"Request Queued!",1:"Request Cancelled!")
 . K ZTSK,ZTDESC,ZTRTN,ZTSAVE,%ZIS,TIUDIV,TIURPT,TIUIFP
 . D HOME^%ZIS
 U IO D BUILD,^%ZISC
 Q
BUILD ; Build list
 N TIUIFP,TIUK
 K ^TMP("TIUD",$J)
 I $D(ZTQUEUED) S ZTREQ="@"
 I +$G(TIUDI("ENTRIES")) D
 . S TIUK=0 F  S TIUK=$O(TIUDI(TIUK)) Q:'TIUK  D
 . . S TIUIFP=$G(TIUDI(TIUK))
 . . D GATHER(TIUIFP,TIUSTDT,TIUENDT,.TIUSVCS)
 E  D
 . S TIUIFP=0
 . F  S TIUIFP=$O(^TIU(8925,"ADIV",TIUIFP)) Q:+TIUIFP'>0  D
 . . D GATHER(TIUIFP,TIUSTDT,TIUENDT,.TIUSVCS)
 D PRINT
 ;
EXIT ; Clean up and exit
 K SELDIV,TIUDI,TIUSTDT,TIUENDT,TIUSVCS K ^TMP("TIUD",$J)
 Q
GATHER(TIUIFP,TIUSTDT,TIUENDT,TIUSVCS) ; Find records for the list
 ; Input   -- TIUIFP  INSTITUTION file (#4) IEN
 ;            (0 = gather all divisions)
 ;            TIUSTDT Start Date
 ;            TIUENDT End Date
 ;            TIUSVCS Service Selection Array
 ; Output  -- None
 N TIUDA,TIUJ,TIUS,TIUTP
 S TIUTP=TIUSTDT
 F  S TIUTP=$O(^TIU(8925.7,"AC",TIUTP)) Q:'TIUTP!(TIUTP>(TIUENDT+1))  D
 . N TIUIEN S TIUIEN=0
 . F  S TIUIEN=$O(^TIU(8925.7,"AC",TIUTP,TIUIEN)) Q:'TIUIEN  D
 . . I $P($G(^TIU(8925,TIUIEN,12)),U,12)'=TIUIFP Q
 . . D ADDELMNT(TIUIEN,.TIUSVCS)
 Q
 ;
ADDELMNT(TIUDA,TIUSVCS) ; Add each element to the list
 ; Input  -- TIUDA   TIU DOCUMENT file (#8925) IEN
 ;           TIUSVCS Service Selection Array
 ; Output -- None
 N TIUASREC,TIUSVC,TIUEDT,TIUD12,TIUIFP,TIUSTAT
 S TIUSTAT=$P($G(^TIU(8925,TIUDA,0)),U,5)
 I TIUSTAT>8 Q
 S TIUASREC=0
 S TIUD12=$G(^TIU(8925,TIUDA,12))
 S TIUEDT=+$P(TIUD12,U),TIUIFP=+$P(TIUD12,U,12)
 F  S TIUASREC=$O(^TIU(8925.7,"B",TIUDA,TIUASREC)) Q:'TIUASREC  D
 . N TIUAS,TIUASSVC
 . S TIUAS=$P(^TIU(8925.7,TIUASREC,0),U,3)
 . I 'TIUAS!$P(^TIU(8925.7,TIUASREC,0),U,4) Q
 . S TIUASSVC=$$PROVSVC^TIULV(TIUAS)
 . I $G(TIUSVCS)="ALL"!($D(TIUSVCS(+TIUASSVC))) D
 . . S TIUAS=$$PERSNAME^TIULC1(TIUAS)
 . . I $P(TIUASSVC,U,2)]"" S TIUASSVC=$P(TIUASSVC,U,2)
 . . E  S TIUASSVC="UNKNOWN"
 . . I TIUAS'="UNKNOWN" S TIUAS=$$NAME^TIULS(TIUAS,"LAST, FI MI")
 . . S ^TMP("TIUD",$J,TIUIFP,TIUASSVC,TIUAS,TIUEDT)=TIUDA
 Q
 ;
PRNT(TIUDA) ; Does document have a parent?
 ; Input  -- TIUDA    TIU Document file (#8925) IEN
 ; Output -- TIUPRNT  Null= TIU Document file (#8925) entry does
 ;                          not have a parent
 ;                    Exists= TIU Document file (#8925) entry is
 ;                            an addendum or ID child.
 ;                            Value: Parent TIU Document file
 ;                                   (#8925) IEN
 N ADDMPRNT,IDPRNT,TIUPRNT
 S TIUPRNT=""
 S ADDMPRNT=+$P($G(^TIU(8925,TIUDA,0)),U,6) ; Addm parent
 I '$D(^TIU(8925,ADDMPRNT,0)) S ADDMPRNT=0
 I ADDMPRNT D
 . S TIUPRNT=ADDMPRNT
 E  D
 . S IDPRNT=+$G(^TIU(8925,TIUDA,21)) ; ID parent
 . I '$D(^TIU(8925,IDPRNT,0)) S IDPRNT=0
 . I IDPRNT D
 . . S TIUPRNT=IDPRNT
 Q TIUPRNT
 ;
ASKRNG(STDT,ENDT) ;Prompt for entry date range
 ; Input  -- None
 ; Output -- 1=Successful and 0=Failure
 ;           STDT  Start Date
 ;           ENDT  End Date
 N DIRUT,DTOUT,DUOUT,Y
 W !!,"Please specify an Entry Date Range:",!
 S STDT=+$$READ^TIUU("DA^:DT:E"," Start Entry Date: ")
 I $D(DIRUT)!(STDT'>0) G ASKRNGQ
 S ENDT=+$$READ^TIUU("DA^"_STDT_":DT:E","Ending Entry Date: ")_"."_235959
 I $D(DIRUT)!(ENDT'>0) G ASKRNGQ
 S Y=1
ASKRNGQ Q +$G(Y)
DHDR(TIUFP,TIUSTDT,TIUENDT) ;
 ;DIVISION HEADER
 N TIUR,TIURNG,TIUINST
 S TIUPG=(+$G(TIUPG))+1
 D DT^DILF("ET","NOW",.TIUR)
 S TIURNG=$$FMTE^XLFDT(TIUSTDT)_" thru "_$$FMTE^XLFDT(TIUENDT)
 S TIUINST=$S(TIUIFP:$P($$NS^XUAF4(TIUIFP),U),1:"ALL DIVISIONS")
 W @IOF,"Pending Additional Signature Documents for "_TIUINST
 W " on "_$$FMTE^XLFDT($$NOW^XLFDT)
 W !,?10,TIURNG,?70,"Page: "_+$G(TIUPG)
 I TIURPT'="F" D
 . W !,"------------------------------------------------------------------------------"
 I TIURPT="F" D
 . W !,"------------------------------------------------------------------------------------------------------------------------------------"
 . W !,"IDENT. SIGNER",?17,"PATIENT",?27,"STATUS",?35,"ENTRY DATE"
 . W ?54,"DOCUMENT TITLE",?81,"DOCUMENT IEN"
 . W !,"------------------------------------------------------------------------------------------------------------------------------------"
 Q
SHDR(TIUSVC) ;
 ; SERVICE HEADER
 W !!?10,"SERVICE: ",TIUSVC
 Q
PRINT ;
 N TIUPG,TIUIFP,TIUOUT,TIUTOT
 S (TIUPG,TIUIFP,TIUOUT,TIUTOT)=0
 F  S TIUIFP=$O(^TMP("TIUD",$J,TIUIFP)) Q:'TIUIFP!(TIUOUT)  D
 . N TIUSVC,TIUDCNT
 . S (TIUSVC,TIUDCNT)=0
 . D DHDR(TIUIFP,TIUSTDT,TIUENDT)
 . F  S TIUSVC=$O(^TMP("TIUD",$J,TIUIFP,TIUSVC)) Q:TIUSVC=""!(TIUOUT)  D
 . . N TIUAS,TIUSVCNT
 . . S (TIUAS,TIUSVCNT)=0
 . . I $Y>(IOSL-5) D ASK Q:TIUOUT  D DHDR(TIUIFP,TIUSTDT,TIUENDT)
 . . I TIURPT="F" D SHDR(TIUSVC)
 . . F  S TIUAS=$O(^TMP("TIUD",$J,TIUIFP,TIUSVC,TIUAS)) Q:TIUAS=""!(TIUOUT)  D
 . . . N TIUEDT
 . . . S TIUEDT=""
 . . . F  S TIUEDT=$O(^TMP("TIUD",$J,TIUIFP,TIUSVC,TIUAS,TIUEDT)) Q:'TIUEDT!(TIUOUT)  D
 . . . . N TIUDA
 . . . . S TIUDA=^TMP("TIUD",$J,TIUIFP,TIUSVC,TIUAS,TIUEDT)
 . . . . I TIURPT="F" D PRNTITEM(TIUDA,TIUAS,TIUEDT)
 . . . . I $Y>(IOSL-5) D ASK Q:TIUOUT  D DHDR(TIUIFP,TIUSTDT,TIUENDT)
 . . . . S TIUSVCNT=TIUSVCNT+1,TIUDCNT=TIUDCNT+1
 . . W !,"  Totals for Service   ",TIUSVC,": ",?55,TIUSVCNT
 . . I $Y>(IOSL-5) D ASK Q:TIUOUT  D DHDR(TIUIFP,TIUSTDT,TIUENDT)
 . Q:TIUOUT
 . N TIUDVSTR S TIUDVSTR=$E($P($$NS^XUAF4(TIUIFP),U),1,25)
 . W !,"Totals for Division    ",TIUDVSTR,": ",?55,TIUDCNT
 . I $O(^TMP("TIUD",$J,TIUIFP)) D ASK Q:TIUOUT
 . S TIUTOT=TIUTOT+TIUDCNT
 Q:TIUOUT
 W !,"Totals for all Divisions: ",?55,TIUTOT
 Q
PRNTITEM(TIUDA,TIUAS,TIUEDT) ;
 N TIUPRNT,TIUPAT,TIUSTAT,TIUTYP,TIUD0,TIUD12,TIULST4,TIUDATE
 S TIUPRNT=$$PRNT(TIUDA)
 S TIUD0=$G(^TIU(8925,TIUDA,0))
 S TIULST4=$E($$GET1^DIQ(2,$G(TIUPAT),.09),6,9)
 S TIUPAT=$$PATPRNT($P($G(TIUD0),U,2))
 S TIUSTAT=$P($G(TIUD0),U,5)
 S TIUSTAT=$S(TIUSTAT:$E($$EXTERNAL^DILFD(8925,.05,"",TIUSTAT),1,11),1:"UNKNOWN")
 S TIUSTAT=$$STATXFER(TIUSTAT)
 S TIUTYP=+TIUD0
 S TIUTYP=$E($P($G(^TIU(8925.1,TIUTYP,0)),U),1,25)
 S TIUDATE=$$FMTE^XLFDT(TIUEDT,2)
 W !,TIUAS,?17,$G(TIUPAT),?27," "_TIUSTAT,?35,$G(TIUDATE)
 W ?54,$G(TIUTYP),?81,TIUDA
 I +$G(TIUPRNT) W " PARENT = "_TIUPRNT
 Q
ASK ;
 I IO=IO(0),$E(IOST)="C" D
 . W ! N DIR,Y S DIR(0)="E" D ^DIR K DIR
 . I Y=""!(Y=0) S TIUOUT=1
 Q
STATXFER(TIUSTAT) ;format a small status string
 I TIUSTAT="COMPLETED"!(TIUSTAT="completed") Q "com"
 I TIUSTAT="UNSIGNED"!(TIUSTAT="unsigned") Q "uns"
 I TIUSTAT="UNCOSIGNED"!(TIUSTAT="uncosigned") Q "uncos"
 I TIUSTAT="UNDICTATED"!(TIUSTAT="undictated") Q "undic"
 I TIUSTAT="UNTRANSCRIBED"!(TIUSTAT="untranscribed") Q "untr"
 I TIUSTAT="UNRELEASED"!(TIUSTAT="unreleased") Q "unrel"
 I TIUSTAT="UNVERIFIED"!(TIUSTAT="unverified") Q "unver"
 I TIUSTAT="AMENDED"!(TIUSTAT="amended") Q "amend"
 Q "???"
PATPRNT(TIUPAT) ; format patient as initials and then last 6 SSN
 N PAT,LST4,INIT,HRCN
 I 'TIUPAT Q ""
 S PAT=$$EXTERNAL^DILFD(8925,.02,"",TIUPAT)
 S LST4=$E($$GET1^DIQ(2,$G(TIUPAT),.09),4,9)
 S HRCN=$$HRCN^TIUR2(TIUPAT,+$G(DUZ(2)))            ;MSC/MGH/MGH PATCH 1011
 S INIT=$E($P(PAT,",",2))_$E($P(PAT,","))
 Q INIT_HRCN