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

DVBCIRPT.m

Go to the documentation of this file.
  1. DVBCIRPT ;ALB/GTS-AMIE C&P INSUFF EXAM TRACKING RPT ; 11/9/94 2:00 PM
  1. ;;2.7;AMIE;**13,19,27,149,184,185,191,193**;Apr 10, 1995;Build 84
  1. ;Per VHA Directive 2004-038, this routine should not be modified.
  1. ;
  1. ;** Version Changes
  1. ; 2.7 - New routine (Enhc 15)
  1. ;
  1. MAIN ;**Select Dte Rng & Rpt Type; call report routine **
  1. ;**DVBA*2.7*191 initializes variable DVBADLMTR to zero before taskman call on detailed report**
  1. F Q:$D(DVBAOUT) DO
  1. .D HOME^%ZIS
  1. .S TVAR(1,0)="0,0,1,2:2,1^Insufficient 2507 Exam Report"
  1. .D WR^DVBAUTL4("TVAR")
  1. .K TVAR
  1. .S DVBAPRTY=$$EXMPRTY^DVBCIUTL("Select Priority of Exam for the Insufficient Exam Report") ;priority of exam selection
  1. .S RPTTYPE=$S((DVBAPRTY?.A)&(DVBAPRTY]""):$$RPTTYPE^DVBCUTA1(),1:"")
  1. .S:((RPTTYPE'="D")&(RPTTYPE'="S")) DVBAOUT=""
  1. .W:'$D(DVBAOUT) !!
  1. .D:'$D(DVBAOUT) DATE^DVBCUTL4(.BEGDT,.ENDDT)
  1. .I $D(ENDDT),(+ENDDT>0) DO
  1. ..S ENDDT=ENDDT_".2359"
  1. ..I RPTTYPE="S" DO
  1. ...D DEVSEL
  1. ...I POP D SUMKILL
  1. ...I 'POP DO
  1. ....I $D(IO("Q")) DO
  1. .....N DVBAI
  1. .....S ZTRTN="SUM^DVBCIRPT",ZTIO=ION
  1. .....S ZTDESC="Summary Insufficient Exam Report"
  1. .....F DVBAI="BEGDT","ENDDT","DVBAPRTY" S ZTSAVE(DVBAI)=""
  1. .....D ^%ZTLOAD
  1. .....N TSK S TSK=$S($D(ZTSK)=0:"C",1:"Y")
  1. .....I TSK="Y" W !!,"Summary Report Queued. Task number: ",ZTSK
  1. .....K ZTSK D CONTMES^DVBCUTL4
  1. .....D SUMKILL
  1. ....I '$D(IO("Q")) D SUM
  1. ...D ^%ZISC
  1. ..I RPTTYPE="D" DO
  1. ...D DETSEL^DVBCIRP1 ;**Select the Reasons and Exams to report
  1. ...I '$D(DVBAQTSL) DO
  1. ....D DEVSEL
  1. ....I POP D KVARS^DVBCIRP1
  1. ....I 'POP DO
  1. .....I $D(IO("Q")) DO
  1. ......N DVBAI,ZTSAVE
  1. ......S ZTRTN="DETAIL^DVBCIRP1",ZTIO=ION
  1. ......S ZTDESC="Detailed Insufficient Exam Report"
  1. ......F DVBAI="BEGDT","ENDDT","DVBAPRTY","DVBAARY(""REASON"",","^TMP($J,""XMTYPE""," S ZTSAVE(DVBAI)="",ZTSAVE("DVBADLMTR")=0
  1. ......D ^%ZTLOAD
  1. ......N TSK S TSK=$S($D(ZTSK)=0:"C",1:"Y")
  1. ......I TSK="Y" W !!,"Detail Report Queued. Task number: ",ZTSK
  1. ......K ZTSK D CONTMES^DVBCUTL4
  1. ......D KVARS^DVBCIRP1
  1. .....I '$D(IO("Q")) W:IOST?1"C-".E @IOF S DVBADLMTR=0 D DETAIL^DVBCIRP1
  1. ....D ^%ZISC
  1. ...K DVBAQTSL
  1. ..D CLEANUP
  1. D KVARS
  1. Q
  1. ;
  1. KVARS ;** Kill the variables used in report
  1. K DVBAOUT,ENDDT,BEGDT,DTOUT,DUOUT,RPTTYPE,DVBACAN,DVBASTAT,DVBAPRTY,DVBADLMTR,NUMRPTS
  1. D CLEANUP
  1. Q
  1. ;
  1. CLEANUP ;** Kill the variables used by the device handler
  1. K %ZIS,POP,%IS,IOP
  1. K IOBS,IOHG,IOPAR,IOUPAR,IOXY,POP,%DT,%YY,%XX,ION,IOPAR
  1. Q
  1. ;
  1. DEVSEL ;** Select the device to report to
  1. S %ZIS="AEQ"
  1. S %ZIS("A")="Output device: "
  1. D ^%ZIS
  1. Q
  1. ;
  1. SUM ;** Set up reason counter array, count all 2507's received
  1. N DVBAEXMP,DVBAI,DVBAP,DVBATVAR,DVBAMCDES,DVBAPREXM
  1. U IO
  1. S (DVBARQCT,DVBAINRQ,DVBAXMCT,DVBAINXM)=0
  1. S DVBACAN("REQ")=0,DVBACAN("EXM")=0
  1. S DVBAENDL=ENDDT
  1. S DVBAEXMP=$S(($G(DVBAPRTY)["BDD"):";BDD;QS;",($G(DVBAPRTY)["IDES"):";IDES;",($G(DVBAPRTY)["AO"):";AO;",1:"")
  1. ; S DVBAMCDES=((DVBAEXMP]"")&(DVBAPRTY'="AO"))
  1. S NUMRPTS=$L(DVBAEXMP,";")
  1. S DVBAMCDES=((DVBAEXMP]"")&(NUMRPTS>3))
  1. K ^TMP("DVBATOTALS",$J) ;for multiple priority reporting
  1. ;
  1. ;** Initialize reason counter array(s)
  1. F DVBARIFN=0:0 S DVBARIFN=$O(^DVB(396.94,DVBARIFN)) Q:+DVBARIFN'>0 DO
  1. .D:(DVBAMCDES)
  1. ..F DVBAP=$P(DVBAEXMP,";",2),$P(DVBAEXMP,";",3) D
  1. ...Q:DVBAP=""
  1. ...S ^TMP("DVBATOTALS",$J,DVBAP,"DVBAINXM",DVBARIFN)=0
  1. .S DVBAINXM(DVBARIFN)=0
  1. D:(DVBAMCDES)
  1. .F DVBAP=$P(DVBAEXMP,";",2),$P(DVBAEXMP,";",3) D
  1. ..Q:DVBAP=""
  1. ..S ^TMP("DVBATOTALS",$J,DVBAP,"DVBAINXM","NO REASON")=0
  1. S DVBAINXM("NO REASON")=0
  1. ;
  1. ;** Count the total and insufficient number of exams and 2507 requests
  1. ; For performance, if multiple reports, store totals in single pass of data
  1. S DVBADTLP=BEGDT-.0001
  1. F S DVBADTLP=$O(^DVB(396.3,"ADP",DVBADTLP)) Q:(DVBADTLP=""!(DVBADTLP>ENDDT)) DO
  1. .S DVBAPRIO=""
  1. .F S DVBAPRIO=$O(^DVB(396.3,"ADP",DVBADTLP,DVBAPRIO)) Q:DVBAPRIO="" DO
  1. ..S DVBADALP=""
  1. ..F S DVBADALP=$O(^DVB(396.3,"ADP",DVBADTLP,DVBAPRIO,DVBADALP)) Q:DVBADALP="" DO
  1. ...;check for Parent Request (retrieve current/parent Priority of Exam)
  1. ...S DVBAPREXM=$$CHKREQ^DVBCIRP1(DVBADALP)
  1. ...;original report run (Exclude new priorities)
  1. ...Q:((DVBAEXMP']"")&((";BDD;QS;IDES;AO;")[(";"_DVBAPREXM_";")))
  1. ...;report for specific Priority of Exam
  1. ...Q:((DVBAEXMP]"")&(DVBAEXMP'[(";"_DVBAPREXM_";")))
  1. ...S:(DVBAMCDES) ^TMP("DVBATOTALS",$J,DVBAPREXM,"DVBARQCT")=$G(^TMP("DVBATOTALS",$J,DVBAPREXM,"DVBARQCT"))+1
  1. ...S DVBARQCT=DVBARQCT+1
  1. ...K DVBAINSF
  1. ...I DVBAPRIO="E" DO
  1. ....S:(DVBAMCDES) ^TMP("DVBATOTALS",$J,DVBAPREXM,"DVBAINRQ")=$G(^TMP("DVBATOTALS",$J,DVBAPREXM,"DVBAINRQ"))+1
  1. ....S DVBAINRQ=DVBAINRQ+1
  1. ....; ;AJF;Request Status conversion
  1. ....I $P(^DVB(396.3,DVBADALP,0),U,18)=7 D
  1. .....S:(DVBAMCDES) ^TMP("DVBATOTALS",$J,DVBAPREXM,"DVBACANREQ")=$G(^TMP("DVBATOTALS",$J,DVBAPREXM,"DVBACANREQ"))+1
  1. .....S DVBACAN("REQ")=DVBACAN("REQ")+1
  1. ....S DVBAINSF=""
  1. ...S DVBAXMDA=""
  1. ...F S DVBAXMDA=$O(^DVB(396.4,"C",DVBADALP,DVBAXMDA)) Q:DVBAXMDA="" DO
  1. ....S:(DVBAMCDES) ^TMP("DVBATOTALS",$J,DVBAPREXM,"DVBAXMCT")=$G(^TMP("DVBATOTALS",$J,DVBAPREXM,"DVBAXMCT"))+1
  1. ....S DVBAXMCT=DVBAXMCT+1
  1. ....I $D(DVBAINSF) DO
  1. .....S:(DVBAMCDES) ^TMP("DVBATOTALS",$J,DVBAPREXM,"DVBAINXM")=$G(^TMP("DVBATOTALS",$J,DVBAPREXM,"DVBAINXM"))+1
  1. .....S DVBAINXM=DVBAINXM+1
  1. .....S DVBARIFN=$P(^DVB(396.4,DVBAXMDA,0),U,11),DVBASTAT=$P(^(0),U,4)
  1. .....S:DVBARIFN="" DVBARIFN="NO REASON"
  1. .....S:(DVBAMCDES) ^TMP("DVBATOTALS",$J,DVBAPREXM,"DVBAINXM",DVBARIFN)=$G(^TMP("DVBATOTALS",$J,DVBAPREXM,"DVBAINXM",DVBARIFN))+1
  1. .....S DVBAINXM(DVBARIFN)=DVBAINXM(DVBARIFN)+1
  1. .....I DVBASTAT="RX" D
  1. ......S:(DVBAMCDES) ^TMP("DVBATOTALS",$J,DVBAPREXM,"DVBACANEXM")=$G(^TMP("DVBATOTALS",$J,DVBAPREXM,"DVBACANEXM"))+1
  1. ......S DVBACAN("EXM")=DVBACAN("EXM")+1
  1. ;
  1. S DVBAEXMP=$S(($G(DVBAPRTY)["BDD"):"BDD,QS",($G(DVBAPRTY)["IDES"):"IDES",($G(DVBAPRTY)["AO"):"AO",1:"")
  1. F DVBAI=1:1:$L(DVBAEXMP,",") D
  1. .S DVBAPRTY=$P(DVBAEXMP,",",DVBAI) ;priority to report on
  1. .D:(DVBAI>1) ;Form Feed between multiple Reports
  1. ..S DVBATVAR(1,0)="0,0,0,0,1^"
  1. ..D WR^DVBAUTL4("DVBATVAR")
  1. .;
  1. .D:(DVBAMCDES) ;reset var cntrs for specific priority
  1. ..S DVBARQCT=+$G(^TMP("DVBATOTALS",$J,DVBAPRTY,"DVBARQCT"))
  1. ..S DVBAINRQ=+$G(^TMP("DVBATOTALS",$J,DVBAPRTY,"DVBAINRQ"))
  1. ..S DVBACAN("REQ")=+$G(^TMP("DVBATOTALS",$J,DVBAPRTY,"DVBACANREQ"))
  1. ..S DVBAXMCT=+$G(^TMP("DVBATOTALS",$J,DVBAPRTY,"DVBAXMCT"))
  1. ..S DVBAINXM=+$G(^TMP("DVBATOTALS",$J,DVBAPRTY,"DVBAINXM"))
  1. ..S DVBAP=0 F S DVBAP=$O(^TMP("DVBATOTALS",$J,DVBAPRTY,"DVBAINXM",DVBAP)) Q:DVBAP="" D
  1. ...S DVBAINXM(DVBAP)=+$G(^TMP("DVBATOTALS",$J,DVBAPRTY,"DVBAINXM",DVBAP))
  1. ..S DVBACAN("EXM")=+$G(^TMP("DVBATOTALS",$J,DVBAPRTY,"DVBACANEXM"))
  1. .;
  1. .D SUMRPT^DVBCIRP1 ;print SUMMARY report
  1. S:$D(ZTQUEUED) ZTREQ="@"
  1. D SUMKILL
  1. D ^%ZISC
  1. Q
  1. ;
  1. SUMKILL ;** Kill the variables used in the summary report
  1. K DVBADTLP,DVBAENDL,DVBARQCT,DVBAINRQ,DVBAXMCT,DVBAINXM
  1. K DVBAPRIO,DVBADALP,DVBAXMDA,DVBAINSF,DVBARIFN
  1. K ^TMP("DVBATOTALS",$J)
  1. Q